Форум программистов, компьютерный форум, киберфорум
C++ Builder: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
Builder 6

Как записать SQL в ADOQuery? Выдает ошибку

11.12.2019, 16:08. Показов 1366. Ответов 10

Студворк — интернет-сервис помощи студентам
Делаю кнопку с выборкой по месяцу. В Edit пишем номер месяца, а в таблице выводит людей с датой рождения в этом месяце при нажатии кнопки. При запуске выдает ошибку. Как можно ее исправить?

C++
1
2
3
4
5
6
7
8
9
10
11
12
void __fastcall TKadry::Button2Click(TObject *Sender)
{
ADOQuery1->Active=false;
ADOQuery1->SQL->Clear();
ADOQuery1->Parameters->Items[0]->Value=("SELECT Сотрудники.КодСотрудника, [Фамилия]+" "+(Left([Имя],1))+"."+(Left([Отчество],1))+"." AS ФамилияИО, Сотрудники.КодДолжности, Сотрудники.ДоляСтавки, Сотрудники.ДатаРождения, (Date()-[ДатаРождения])\360 AS Возраст, Сотрудники.ДатаПриемаНаРаботу, (Date()-[ДатаПриемаНаРаботу])\360 AS Стаж, Сотрудники.ДатаЗаключенияКонтракта, Сотрудники.СрокКонтракта, [ДатаЗаключенияКонтракта]+365*[СрокКонтракта] AS [Контракт истек], (((Date()-[ДатаПриемаНаРаботу])\365)\2) AS [Код стажа]");
ADOQuery1->Parameters->Items[1]->Value=("FROM Сотрудники");
ADOQuery1->Parameters->Items[2]->Value=("WHERE Month(Сотрудники.[ДатаРождения])=");
ADOQuery1->Parameters->Items[2]->Add(Edit1->Text);
ADOQuery1->Parameters->Items[3]->Value=("ORDER BY [Фамилия]+" "+(Left([Имя],1))+"."+(Left([Отчество],1))+"."; ");
ADOQuery1->Active=true;
 
}
Миниатюры
Как записать SQL в ADOQuery? Выдает ошибку  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.12.2019, 16:08
Ответы с готовыми решениями:

Как записать SQL в ADOQuery? Выдает ошибку
Делаю кнопку, которая делает выборку из запроса БД ACCESS по номеру месяца в дате рождения. При редактировании SQL запроса выводит ошибку....

ADOQuery - выдает ошибку
Соединил Вelphi7.0 c MySQL5.1 через driver ODBC. При выполнении SQL-запроса при помощи функции DELETE или load data infile сам запрос...

Как на C++ записать СТРОКИ в обратном порядке? Выдает ошибку
как на C++ записать СТРОКИ в обратном порядке?? Почти сделал. #include <iostream> #include <string> #include <stack> ...

10
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
11.12.2019, 16:18
Цитата Сообщение от Evg0209 Посмотреть сообщение
Делаю кнопку с выборкой по месяцу. В Edit пишем номер месяца, а в таблице выводит людей с датой рождения в этом месяце при нажатии кнопки. При запуске выдает ошибку. Как можно ее исправить?
Наверное, запрос надо записывать в свойство SQL, а не в Parameters
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
11.12.2019, 16:24  [ТС]
Извиняюсь, исправил. Ошибка та же.

C++
1
2
3
4
5
6
7
8
9
10
11
12
void __fastcall TKadry::Button2Click(TObject *Sender)
{
ADOQuery1->Active=false;
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("SELECT Ñîòðóäíèêè.ÊîäÑîòðóäíèêà, [Ôàìèëèÿ]+" "+(Left([Èìÿ],1))+"."+(Left([Îò÷åñòâî],1))+"." AS ÔàìèëèÿÈÎ, Ñîòðóäíèêè.ÊîäÄîëæíîñòè, Ñîòðóäíèêè.ÄîëÿÑòàâêè, Ñîòðóäíèêè.ÄàòàÐîæäåíèÿ, (Date()-[ÄàòàÐîæäåíèÿ])\360 AS Âîçðàñò, Ñîòðóäíèêè.ÄàòàÏðèåìàÍàÐàáîòó, (Date()-[ÄàòàÏðèåìàÍàÐàáîòó])\360 AS Ñòàæ, Ñîòðóäíèêè.ÄàòàÇàêëþ÷åíèÿÊîíòðàêòà, Ñîòðóäíèêè.ÑðîêÊîíòðàêòà, [ÄàòàÇàêëþ÷åíèÿÊîíòðàêòà]+365*[ÑðîêÊîíòðàêòà] AS [Êîíòðàêò èñòåê], (((Date()-[ÄàòàÏðèåìàÍàÐàáîòó])\365)\2) AS [Êîä ñòàæà]");
ADOQuery1->SQL->Add("FROM Ñîòðóäíèêè");
ADOQuery1->SQL->Add("WHERE Month(Ñîòðóäíèêè.[ÄàòàÐîæäåíèÿ])=");
ADOQuery1->SQL->Add(Edit1->Text);
ADOQuery1->SQL->Add("ORDER BY [Ôàìèëèÿ]+" "+(Left([Èìÿ],1))+"."+(Left([Îò÷åñòâî],1))+"."; ");
ADOQuery1->Active=true;
 
}
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
11.12.2019, 16:26  [ТС]
Вот фото
Миниатюры
Как записать SQL в ADOQuery? Выдает ошибку  
0
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
11.12.2019, 16:29
Правильно написать...
C++
1
2
3
4
5
6
7
8
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("SELECT [Сотрудники.КодСотрудника], [Фамилия]+" "+(Left([Имя],1))+"."+(Left([Отчество],1))+"." AS [ФамилияИО], [Сотрудники.КодДолжности], [Сотрудники.ДоляСтавки], [Сотрудники.ДатаРождения], (Date()-[ДатаРождения])\360 AS [Возраст], [Сотрудники.ДатаПриемаНаРаботу], (Date()-[ДатаПриемаНаРаботу])\360 AS [Стаж], [Сотрудники.ДатаЗаключенияКонтракта], [Сотрудники.СрокКонтракта], [ДатаЗаключенияКонтракта]+365*[СрокКонтракта] AS [Контракт истек], (((Date()-[ДатаПриемаНаРаботу])\365)\2) AS [Код стажа]");
ADOQuery1->SQL->Add("FROM [Сотрудники]");
ADOQuery1->SQL->Add("WHERE Month([Сотрудники.ДатаРождения])=:p");
ADOQuery1->SQL->Add("ORDER BY [ФамилияИО]");
ADOQuery1->Parameters->ParamByName("p")->Value = Edit1->Text;
ADOQuery1->Open();
НО!!!
1. За работоспособность этого запроса я абсолютно не отвечаю, поэтому не надо претензий, что, мол, не работает, ибо прежде, чем переносить заброс в свой проект, его необходимо отладить в самой СУБД до рабочего состояния.
2. База спроектирована просто ужасно!!!
3. Сплошная головная боль - наименование таблиц и полей на кириллице! Отвыкайте, пока не поздно - в будущем избежите многих-многих проблем
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
11.12.2019, 16:36  [ТС]
Спасибо, помогли с параметром)
Только вот ошибка та же и осталась. Что можно сделать, чтобы он не ругался на кириллице? В БД исправлять не вариант.
Или как иначе сделать выборку?
0
4217 / 3059 / 583
Регистрация: 21.01.2011
Сообщений: 13,203
11.12.2019, 16:49
Цитата Сообщение от Evg0209 Посмотреть сообщение
Что можно сделать, чтобы он не ругался на кириллице?
Ты же не огласил СУБД. В разных СУБД нестандартные наименования объектов заключаются в разные символы.
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
11.12.2019, 16:51  [ТС]
СУБД ACCESS
0
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
11.12.2019, 17:24
Evg0209, сделайте подобный запрос в самом Access-е, чтобы он там работал. В секцию WHERE вписывайте пока какое-нибудь конкретное значение... Когда запрос будет работоспособным - выкладывайте его текст.
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 7
11.12.2019, 17:32  [ТС]
Запрос работает исправно как в самом ACCESS так и при внесении его вручную в ADOQuery. Мне нужна помощь во внесении текста этого запроса с изменяемым параметром "р"(берется из Edit1) в SQL ADOQuery.

SQL
1
2
3
4
SELECT Сотрудники.КодСотрудника, [Фамилия]+" "+(LEFT([Имя],1))+"."+(LEFT([Отчество],1))+"." AS ФамилияИО, Сотрудники.КодДолжности, Сотрудники.ДоляСтавки, Сотрудники.ДатаРождения, (DATE()-[ДатаРождения])\360 AS Возраст, Сотрудники.ДатаПриемаНаРаботу, (DATE()-[ДатаПриемаНаРаботу])\360 AS Стаж, Сотрудники.ДатаЗаключенияКонтракта, Сотрудники.СрокКонтракта, [ДатаЗаключенияКонтракта]+365*[СрокКонтракта] AS [Контракт истек], (((DATE()-[ДатаПриемаНаРаботу])\365)\2) AS [Код стажа]
FROM Сотрудники
WHERE MONTH(Сотрудники.[ДатаРождения])=10
ORDER BY [Фамилия]+" "+(LEFT([Имя],1))+"."+(LEFT([Отчество],1))+".";

Это сейчас в SQL ADOQuery и работает исправно. Оно мне выводит всех людей родившихся в 10 месяце. А мне надо, чтобы значение "10" бралось откуда-либо, куда я его запишу и ставилось на место "10"
0
Модератор
 Аватар для D1973
9921 / 6457 / 2457
Регистрация: 21.01.2014
Сообщений: 27,399
Записей в блоге: 3
12.12.2019, 08:48
А вот так?
C++
1
2
3
4
5
6
7
8
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("SELECT Сотрудники.КодСотрудника, [Фамилия]+\" \"+(LEFT([Имя],1))+\".\"+(LEFT([Отчество],1))+\".\" AS ФамилияИО, Сотрудники.КодДолжности, Сотрудники.ДоляСтавки, Сотрудники.ДатаРождения, (DATE()-[ДатаРождения])\360 AS Возраст, Сотрудники.ДатаПриемаНаРаботу, (DATE()-[ДатаПриемаНаРаботу])\360 AS Стаж, Сотрудники.ДатаЗаключенияКонтракта, Сотрудники.СрокКонтракта, [ДатаЗаключенияКонтракта]+365*[СрокКонтракта] AS [Контракт истек], (((DATE()-[ДатаПриемаНаРаботу])\365)\2) AS [Код стажа]");
ADOQuery1->SQL->Add("FROM Сотрудники");
ADOQuery1->SQL->Add("WHERE MONTH(Сотрудники.[ДатаРождения])=:p");
ADOQuery1->SQL->Add("ORDER BY [Фамилия]+\" \"+(LEFT([Имя],1))+\".\"+(LEFT([Отчество],1))+\".\"");
ADOQuery1->Parameters->ParamByName("p")->Value = Edit1->Text;
ADOQuery1->Open();
Добавлено через 5 минут
или так?
C++
1
2
3
4
5
6
7
8
ADOQuery1->Close();
ADOQuery1->SQL->Clear();
ADOQuery1->SQL->Add("SELECT Сотрудники.КодСотрудника, [Фамилия]+' '+(LEFT([Имя],1))+'.'+(LEFT([Отчество],1))+'.' AS ФамилияИО, Сотрудники.КодДолжности, Сотрудники.ДоляСтавки, Сотрудники.ДатаРождения, (DATE()-[ДатаРождения])\\360 AS Возраст, Сотрудники.ДатаПриемаНаРаботу, (DATE()-[ДатаПриемаНаРаботу])\\360 AS Стаж, Сотрудники.ДатаЗаключенияКонтракта, Сотрудники.СрокКонтракта, [ДатаЗаключенияКонтракта]+365*[СрокКонтракта] AS [Контракт истек], (((DATE()-[ДатаПриемаНаРаботу])\\365)\\2) AS [Код стажа]");
ADOQuery1->SQL->Add("FROM Сотрудники");
ADOQuery1->SQL->Add("WHERE MONTH(Сотрудники.[ДатаРождения])=:p");
ADOQuery1->SQL->Add("ORDER BY [Фамилия]+' '+(LEFT([Имя],1))+'.'+(LEFT([Отчество],1))+'.'");
ADOQuery1->Parameters->ParamByName("p")->Value = Edit1->Text;
ADOQuery1->Open();
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.12.2019, 08:48
Помогаю со студенческими работами здесь

ADOQuery.Close выдает ошибку: BOF или EOF имеют значение True ... Для выполнения операции требуется текущая запись.
Пожалуйста, помогите справиться с ADOQuery: ADOQuery.Close выдает ошибку: BOF или EOF имеют значение True ... Для выполнения операции...

Как правильно перенести из CSV файла в Sql Таблицу? Код вроде прав, но выдает ошибку
Здравствуйте! Не могу разобраться. пытаюсь перенести из csv файла в Sql таблицу, Sql таблица уже создана, но надо в нее добавить еще инфо...

SQL ошибку выдает
Dim strSql As String strSql = "update request set = " & numberOfRequest & "#" & Forms!form1!Ïîëå0.Value & "where = " &...

SQL.Delphi. Выдает ошибку
procedure TForm1.Button17Click(Sender: TObject); begin frmdm.ADOQuery1.SQL.Text:='Insert Into ЕГЭ (idАбитуриента, математика,...

Анализатор SQL выдает синтаксическую ошибку
UPDATE Projects SET projName = проба, customer = я, executer = я, manager = 1, start = 01.06.2012, finish = 22.06.2012, priority = 0,...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru