| 
| 
 | Вопрос # 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]:присвоение значения параметру надо делать после формирования текста запроса. |  Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |