Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.04.2015, 16:13
xGoOdI xGoOdI вне форума
Прохожий
 
Регистрация: 28.04.2015
Сообщения: 2
Версия Delphi: Lazarus
Репутация: 10
По умолчанию Проблема с SQL запросом

Всем доброго времени суток!
Делаю я тут, значит, базу данных.
И у меня возникла такая ошибка.
У меня есть SQL запрос, который по нажатию кнопки должен брать айди из одной таблицы и записывать в другую, но еще он должен записывать данные введенные пользователем в DateEdit1, в итоге, как я понял, получается 2 оператора insert в одном запросе и из-за этого выдает ошибку или я понял что-то не так)
Подскажите пожалуйста знающие люди.
Вот процедура на кнопку:

Код:
procedure TForm11.Button1Click(Sender: TObject);
begin
DataModule1.SQLQuery5.Close;
DataModule1.SQLQuery5.SQL.Clear;
DataModule1.SQLQuery5.SQL.Add('insert into SCHEDULE(ID_DIRECTION)');
DataModule1.SQLQuery5.SQL.Add('select ID_DIRECTION');
DataModule1.SQLQuery5.SQL.Add('FROM DIRECTION');
DataModule1.SQLQuery5.SQL.Add('UNION');
DataModule1.SQLQuery5.SQL.Add('insert into SCHEDULE(DATE_TIME) values (:DATE_TIME)');
DataModule1.SQLQuery5.ParamByName('DATE_TIME').AsDate := DateEdit1.Date;
DataModule1.SQLQuery5.ExecSQL;
DataModule1.SQLTransaction1.Commit;
DataModule1.SQLQuery5.SQL.Text:='select * from SCHEDULE';
DataModule1.SQLQuery5.Open;
Close;
end;

Ошибка такого рода:

Проект project1 вызвал класс исключения 'EIBDatabaseError' с сообщением:
IBCon: PrepareStatement:
-Dynamic SQL Error
-SQL error code=-104
-Token unknown
-line5, column 1
-insert

Как я понял, он ругается на эту строку, т.к. это линия 5:

Код:
DataModule1.SQLQuery5.SQL.Add('insert into SCHEDULE(DATE_TIME) values (:DATE_TIME)');
Ответить с цитированием
  #2  
Старый 28.04.2015, 19:00
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Попробуйте убрать или заменить (напр. на "?") префикс именованного параметра поскольку это работает только в тексте запроса, а у вас здесь микс
Ответить с цитированием
  #3  
Старый 28.04.2015, 19:15
Аватар для Freeman
Freeman Freeman вне форума
Местный
 
Регистрация: 05.10.2012
Адрес: Санкт-Петербург
Сообщения: 576
Версия Delphi: 6
Репутация: выкл
По умолчанию

Оператор union неприменим к insert, только к select.
__________________
Не стоит путать форумы с богадельнями. © Bargest
Ответить с цитированием
  #4  
Старый 28.04.2015, 19:54
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Да вообще бред в запросе написан. Даже если поправить, что бы работало, то в результате выполнения такой логики в таблицу будет вставлеы все ID из таблицы DIRECTION (отдельные строки, скажем их N) и еще одна строка с пустым ID, но с переданным значением в поле DATE_TIME. Итого N+1 строка.
Видимо, имелось в виду что-то типа такого:
Код:
insert into SCHEDULE(ID_DIRECTION, DATE_TIME)
(SELECT ID_DIRECTION, :DATE_TIME
from DIRECTION)
Ответить с цитированием
Этот пользователь сказал Спасибо lmikle за это полезное сообщение:
xGoOdI (29.04.2015)
  #5  
Старый 29.04.2015, 16:14
xGoOdI xGoOdI вне форума
Прохожий
 
Регистрация: 28.04.2015
Сообщения: 2
Версия Delphi: Lazarus
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Да вообще бред в запросе написан. Даже если поправить, что бы работало, то в результате выполнения такой логики в таблицу будет вставлеы все ID из таблицы DIRECTION (отдельные строки, скажем их N) и еще одна строка с пустым ID, но с переданным значением в поле DATE_TIME. Итого N+1 строка.
Видимо, имелось в виду что-то типа такого:
Код:
insert into SCHEDULE(ID_DIRECTION, DATE_TIME)
(SELECT ID_DIRECTION, :DATE_TIME
from DIRECTION)
Да, браток, спасибо! Именно это я и имел ввиду)
Ответить с цитированием
  #6  
Старый 29.04.2015, 21:26
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Цитата:
Сообщение от xGoOdI
Да, браток, спасибо! Именно это я и имел ввиду)

Только без фамильярности, плз. Есть мнение, что я раза в 2 старше.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 07:51.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter