Форум: "Базы";
Поиск по всему сайту: 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.023 c
3-66802           TwoK                  2002-02-24 12:14  2002.03.21  
Не подскажете альтернативные движки кроме BDE? Фриварные, шароварные - все равно...(-)


1-66878           Vacheslav             2002-03-03 20:11  2002.03.21  
Размеры компонентов


3-66792           Bura                  2002-02-22 22:09  2002.03.21  
Дурацкий вопрос...


6-66950           xmag                  2002-01-04 21:41  2002.03.21  
Вопрос о TThread & TClientSocket


1-66913           Dimedrol              2002-03-06 13:29  2002.03.21  
File of Record - лишние данные