С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787

Не могу правильно составить SQL запрос

13.11.2013, 19:28. Показов 1086. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет, хочу в SQL запросе посчитать сумму, таким кодом считаю разницу в валюте
C++
1
2
3
4
                DataM->ADOQuery->Close();
                DataM->ADOQuery->SQL->Text="SELECT *, (Price * :M) AS Цена FROM  "+ListBox1->Items->Strings[ListBox1->ItemIndex];
                DataM->ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
                DataM->ADOQuery->Open();
но как туда еще добавить чтоб считало сумму.
Есть поле Qty, это количество, нужно его умножить на поле Price
как это добавить в мой код ?
C++
1
SELECT *, (Price * :M, Price * Qty ) AS Цена FROM  "+ListBox1->Items->Strings[ListBox1->ItemIndex];
Выдает ошибку
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.11.2013, 19:28
Ответы с готовыми решениями:

SQL запрос не могу составить
Здравствуйте уважаемые форумчане, у меня такой вопрос...имеется в общем код. void __fastcall TForm1::Button6Click(TObject *Sender) {...

Правильно составить sql запрос
Необходимо заменить \http: на http: проблема в символе \ Поправьте меня: UPDATE element SET name = ( REPLACE (name, '\http:',...

Как правильно составить SQL-запрос?
Пытаюсь писать службу, взаимодействующую с SQL. Вопрос по запросу у меня....имеется следующий код protected override void OnStart(string...

14
164 / 49 / 27
Регистрация: 04.06.2013
Сообщений: 636
13.11.2013, 21:54
Цитата Сообщение от tdo22 Посмотреть сообщение
C++
1
SELECT *, (Price * :M, Price * Qty ) AS Цена FROM  "+ListBox1->Items->Strings[ListBox1->ItemIndex];
Выдает ошибку
Так сдесь перед + стоят непонятные кавычки

Добавлено через 17 секунд
какая именно ошибка???
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
13.11.2013, 21:58  [ТС]
Цитата Сообщение от mish_k98 Посмотреть сообщение
Так сдесь перед + стоят непонятные кавычки

Добавлено через 17 секунд
какая именно ошибка???
я эту строку взял с кода, который сверху, если на него посмотреть там видно зачем кавычки.
Ошибка:
Code
1
First chance exception at $76CEC41F. Exception class EOleException with message 'Ошибка синтаксиса (запятая) в выражении запроса '(Price * ?, Prise* Qty)''. Process Project1.exe (2616)
0
164 / 49 / 27
Регистрация: 04.06.2013
Сообщений: 636
13.11.2013, 22:06
не знаю чем помочь,пробовал у себя, так мне вообще другую ошибку даёт,правда код не копия вашего.

Добавлено через 40 секунд
если не принципиально, попробуй просто сделать 2 запроса.
1
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
13.11.2013, 22:35  [ТС]
можно пример как сделать двумя запросами ?
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
13.11.2013, 23:02
но как туда еще добавить чтоб считало сумму?
Вот так
C++
1
"SELECT( Price * Qty ) AS Цена  FROM  " +ListBox1->Items->Strings[ListBox1->ItemIndex];
Добавлено через 16 минут
C++
1
2
3
4
5
6
7
8
       ADOQuery->Close();
       AnsiString text  = "SELECT *FROM (SELECT (Price * :M) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       text += " UNION ALL ";
       text += " SELECT *FROM (SELECT(Price * Qty) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       ADOQuery->SQL->Clear();
       ADOQuery->SQL->Text = text;
       ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
       ADOQuery->Open();
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
14.11.2013, 00:48  [ТС]
Цитата Сообщение от Sasha Посмотреть сообщение
Вот так
C++
1
"SELECT( Price * Qty ) AS Цена  FROM  " +ListBox1->Items->Strings[ListBox1->ItemIndex];
Добавлено через 16 минут
C++
1
2
3
4
5
6
7
8
       ADOQuery->Close();
       AnsiString text  = "SELECT *FROM (SELECT (Price * :M) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       text += " UNION ALL ";
       text += " SELECT *FROM (SELECT(Price * Qty) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       ADOQuery->SQL->Clear();
       ADOQuery->SQL->Text = text;
       ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
       ADOQuery->Open();
на второй строке ошибка:
Code
1
2
3
[bcc32 Error] Core.cpp(159): E2141 Declaration syntax error
  Full parser context
    Core.cpp(143): parsing: void _fastcall TMainForm::ListBox1DblClick(TObject *)
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
14.11.2013, 00:58
А какая у тебя версия Билдера?
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
14.11.2013, 00:59  [ТС]
XE5
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
14.11.2013, 01:00
А так?
C++
1
2
3
4
5
6
7
8
       ADOQuery->Close();
       AnsiString text  = L"SELECT *FROM (SELECT (Price * :M) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       text += L" UNION ALL ";
       text += L" SELECT *FROM (SELECT(Price * Qty) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       ADOQuery->SQL->Clear();
       ADOQuery->SQL->Text = text;
       ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
       ADOQuery->Open();
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
14.11.2013, 01:02  [ТС]
Цитата Сообщение от Sasha Посмотреть сообщение
А так?
C++
1
2
3
4
5
6
7
8
       ADOQuery->Close();
       AnsiString text  = L"SELECT *FROM (SELECT (Price * :M) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       text += L" UNION ALL ";
       text += L" SELECT *FROM (SELECT(Price * Qty) AS Цена  FROM " + ListBox1->Items->Strings[ListBox1->ItemIndex]);
       ADOQuery->SQL->Clear();
       ADOQuery->SQL->Text = text;
       ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
       ADOQuery->Open();
так я тоже делал, не помогло,
почему-то ругается на +
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
14.11.2013, 01:04
UnicodeString text
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
14.11.2013, 01:11  [ТС]
не помогло, сейчас попробую сделать на параметрах

Добавлено через 3 минуты
сделал так:
C++
1
2
3
4
5
6
7
8
       DataM->ADOQuery->Close();
       DataM->ADOQuery->SQL->Text = "SELECT *FROM (SELECT (Price * :A) AS Цена  FROM :B)";
       DataM->ADOQuery->Parameters->ParamByName("A")->Value=Edit1->Text;
       DataM->ADOQuery->Parameters->ParamByName("B")->Value=ListBox1->Items->Strings[ListBox1->ItemIndex];
       DataM->ADOQuery->SQL->Text = " UNION ALL ";
       DataM->ADOQuery->SQL->Text = " SELECT *FROM (SELECT(Price * Qty) AS Цена  FROM :C)";
       DataM->ADOQuery->Parameters->ParamByName("C")->Value=ListBox1->Items->Strings[ListBox1->ItemIndex];
       DataM->ADOQuery->Open();
выдает:
Code
1
First chance exception at $76CEC41F. Exception class EOleException with message 'Ошибка синтаксиса в предложении FROM'. Process Project1.exe (7148)
0
 Аватар для Sasha
4956 / 2420 / 531
Регистрация: 05.06.2008
Сообщений: 7,518
Записей в блоге: 3
14.11.2013, 01:17
Начнём с того что параметры должны писаться после текста запроса, а у тебя они посредине запроса. Поставь их перед Open
0
14 / 14 / 13
Регистрация: 14.02.2013
Сообщений: 787
14.11.2013, 01:39  [ТС]
ставил уже, даже если пишу только так:
C++
1
2
3
4
5
       DataM->ADOQuery->Close();
       DataM->ADOQuery->SQL->Text = "SELECT * FROM (SELECT (Price * :A) AS Цена  FROM :B)";
       DataM->ADOQuery->Parameters->ParamByName("A")->Value=Edit1->Text;
       DataM->ADOQuery->Parameters->ParamByName("B")->Value=ListBox1->Items->Strings[ListBox1->ItemIndex];
       DataM->ADOQuery->Open();
видает:
Code
1
First chance exception at $76CEC41F. Exception class EOleException with message 'Ошибка синтаксиса в предложении FROM'. Process Project1.exe (4744)
Добавлено через 20 минут
Вот так работает:
C++
1
2
3
4
5
6
7
8
       DataM->ADOQuery->Close();
       AnsiString text  = "SELECT * FROM (SELECT *,(Price * :M) AS Цена  FROM "+ListBox1->Items->Strings[ListBox1->ItemIndex]+")";
       text += " UNION ALL ";
       text += " SELECT * FROM (SELECT *,(Price * Qty) AS Сумма  FROM "+ListBox1->Items->Strings[ListBox1->ItemIndex]+")";
       DataM->ADOQuery->SQL->Clear();
       DataM->ADOQuery->SQL->Text = text;
       DataM->ADOQuery->Parameters->ParamByName("M")->Value=Edit1->Text;
       DataM->ADOQuery->Open();
Но, теперь в гриде появляеться две строки
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.11.2013, 01:39
Помогаю со студенческими работами здесь

Не могу составить запрос правильно :/
Что хочу сделать: ввожу дату предполагаемого въезда - мне выводится список комнат, которые свободны (Брони, которая бы припадала на данный...

Не могу правильно составить запрос
Задача запроса - выбрать самую последнюю запись по каждой из трех пластиковых зарплатных карт. Запрос у меня был такой: SELECT...

Как правильно составить SQL запрос в Delphi
Нужно чтобы текст который находится в EDIT1 переходил в запрос try ADOQuery4.SQL.Clear; ADOQuery4.SQL.Add('SELECT * FROM...

Как правильно составить запрос к SQL Server?
всем привет! программа должна по нажатию кнопки писать в базу данных: this.textBox2.Text = "1"; ...

Подскажите как правильно составить sql запрос
Имеются две никак между собой не связанных табилцы (БД MYSQL), в первой таблице 4 поля и во второй таблице 4 поля, нужно взять какое-нибудь...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru