Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.03.21;
Скачать: CL | DM;

Вниз

Передача переменных на 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;

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



Страницы: 1 вся ветка

Текущий архив: 2002.03.21;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.014 c
3-66784
JEff
2002-02-22 18:16
2002.03.21
Автоматическая


3-66806
Jony
2002-02-19 10:22
2002.03.21
Маразмы с DBGrid


3-66778
SAN
2002-02-14 18:46
2002.03.21
MIDAS + IB


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


1-66837
dolmat
2002-03-06 12:22
2002.03.21
печать подобно DOS