|
Вопрос # 3 517/ вопрос открыт / |
|
Приветствую, уважаемые эксперты!
Подскажите пожалуйста, у меня возникает такая ситуация:
Есть объект DBLookupListBox, в нем отображается результат запроса, мне надо этот запрос немного перестроить и ограничить результат выборки, я это осуществляю с помощью применения
динамического запроса. При его выполнении возникает ситуация,при которой в параметр,записывается правильное значение,которое существует в соответствующем поле таблицы, но при этом DBLookupListBox становится пустым, как будто условиям новой выборки ничего не соответсвует. С чем это может быть связано?
Приложение: Переключить в обычный режим- ADOQuery2.Active:=false; ADOQuery2.Parameters.ParamByName('aa').Value:=DBLookupComboBox1.KeyValue;
- ADOQuery2.SQL.Clear;
- ADOQuery2.SQL.Add('select pole1');
- ADOQuery2.SQL.Add('from table1');
- ADOQuery2.SQL.Add('where pole2=''2D line''');
- ADOQuery2.SQL.Add('and pole3 IN');
- ADOQuery2.SQL.Add('(select pole4');
- ADOQuery2.SQL.Add('from table1');
- ADOQuery2.SQL.Add('where pole5 like :aa )');
- ADOQuery2.Active:=true;
 |
Вопрос задала: MStar (статус: Посетитель)
Вопрос отправлен: 12 декабря 2009, 00:25
Состояние вопроса: открыт, ответов: 1.
|
Ответ #1. Отвечает эксперт: Мережников Андрей
Здравствуйте, MStar!
При изменении значения параметра в запросе - запрос закрывается (так же, как в случае изменения текста запроса). Т.е. правильно делать так: 1)закрыть запрос; 2) установить значение параметра (кстати, а зачем использовать параметр, если запрос формируется динамически - не проще ли сразу подставить нужное значение в текст запроса?); 3)Открыть запрос.
Да, еще совет - текст динамического запроса лучше формируйте сначала в переменную типа string, а затем уже делайте SQL.Add(<переменная>);
 |
Ответ отправил: Мережников Андрей (статус: Абитуриент)
Время отправки: 14 декабря 2009, 18:56
Оценка за ответ: 3
|
Мини-форум вопроса
Всего сообщений: 2; последнее сообщение — 18 декабря 2009, 18:58; участников в обсуждении: 2.
|
MStar (статус: Посетитель), 16 декабря 2009, 20:39 [#1]:
Большое спасибо!Радует что ответ на столь простой вопрос все же был получен.По поводу пункта 2 в ответе могу сказать, что в принципе для меня это не новость, мне просто интересен был именно этот способ, с использованием параметра. Не понимаю только почему вариант с простой деактивацией запроса хуже чем close,но видимо так надо,хотя в литературе в листингах везде для выполнения таких операций используется деактивация. Еще раз благодарю!
|
|
Мережников Андрей (статус: Абитуриент), 18 декабря 2009, 18:58 [#2]:
присвоение значения параметру надо делать после формирования текста запроса.
|
Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.
|