Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 3 517

/ вопрос открыт /

Приветствую, уважаемые эксперты!
Подскажите пожалуйста, у меня возникает такая ситуация:
Есть объект DBLookupListBox, в нем отображается результат запроса, мне надо этот запрос немного перестроить и ограничить результат выборки, я это осуществляю с помощью применения
динамического запроса. При его выполнении возникает ситуация,при которой в параметр,записывается правильное значение,которое существует в соответствующем поле таблицы, но при этом DBLookupListBox становится пустым, как будто условиям новой выборки ничего не соответсвует. С чем это может быть связано?

Приложение:
  1. ADOQuery2.Active:=false; ADOQuery2.Parameters.ParamByName('aa').Value:=DBLookupComboBox1.KeyValue;
  2. ADOQuery2.SQL.Clear;
  3. ADOQuery2.SQL.Add('select pole1');
  4. ADOQuery2.SQL.Add('from table1');
  5. ADOQuery2.SQL.Add('where pole2=''2D line''');
  6. ADOQuery2.SQL.Add('and pole3 IN');
  7. ADOQuery2.SQL.Add('(select pole4');
  8. ADOQuery2.SQL.Add('from table1');
  9. ADOQuery2.SQL.Add('where pole5 like :aa )');
  10. ADOQuery2.Active:=true;


MStar Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задала: 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

MStar (статус: Посетитель), 16 декабря 2009, 20:39 [#1]:

Большое спасибо!Радует что ответ на столь простой вопрос все же был получен.По поводу пункта 2 в ответе могу сказать, что в принципе для меня это не новость, мне просто интересен был именно этот способ, с использованием параметра. Не понимаю только почему вариант с простой деактивацией запроса хуже чем close,но видимо так надо,хотя в литературе в листингах везде для выполнения таких операций используется деактивация. Еще раз благодарю!
Мережников Андрей

Мережников Андрей (статус: Абитуриент), 18 декабря 2009, 18:58 [#2]:

присвоение значения параметру надо делать после формирования текста запроса.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:49
Выполнено за 0.02 сек.