Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.21;
Скачать: [xml.tar.bz2];




Вниз

Передача переменных на MSSQL7 через ADOQuery 


Andrey V. Zuev   (2002-02-22 14:05) [0]

Имеется компонент TADOquery, который содержит запрос к БД, хранящейся на сервере MSSQL7 (paramcheck:=false):
SQL.Clear;
SQL.Add("select count(*) from ship where (ship_num = : snum)");
Prepared:=false;
Parameters.Clear;
Parameters.CreateParameter("snum", ftString, pdInput, 6, Ship_Num);
Prepared:=true;
Open;

В DesignTime все работает на ура в любом виде, но в RunTime вот
при попытке активации запроса возникает ошибка: "INCORRECT SYNTAX NEAR ":"".
Без скобок и пробелов (перед и после ":") тоже не работает. =(
Параметр криэйтится вроде правильно...
Где грабли? При работе с БДЕ таких проблем не возникало...



McSimm   (2002-02-22 15:32) [1]

Приведенный вами пример выдает ошибку, после того как я убрал пробел после двоеточия, - все заработало



Andrey V. Zuev   (2002-02-22 16:55) [2]

В моем случае (как это ни странно) это не помогает и я об этом написал ( "... Без скобок и пробелов (перед и после ":") тоже не работает....").
Проблему решил таким тривиальным способом (поскольку динамические запросы с параметрами не работают - надо сделать их статическими =)):

SQL.Clear;
SQLString:="select count(*) from ship where ship_num = ""%s""";
SQL.Add(Format(SQLString, [Ship_Num]));
Open;

Вот и всё. =)
Причем таким способом можно динамически менять не только значения параметров, но и столбцы, названия таблиц и т.д.




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.03.21;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.034 c
1-66849           НЕО                   2002-03-05 15:08  2002.03.21  
Типа консольное приложение


1-66917           archer                2002-03-06 16:40  2002.03.21  
Проблема с Delphi5 под Win2000


1-66927           Aleksandr             2002-03-06 14:10  2002.03.21  
Как врезать Define в проект?


6-66942           Nikolay               2002-01-05 21:50  2002.03.21  
TCP Client


1-66895           der                   2002-03-06 08:23  2002.03.21  
круговерть с DLL