Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
  #4  
Старый 19.08.2011, 23:03
chainik chainik вне форума
Начинающий
 
Регистрация: 30.06.2008
Сообщения: 140
Репутация: 8882
По умолчанию

Я выкрутился следующим образом
в строке запроса я пишу заведомо истинное условие (1>0)
и это дает мне возможность написать where
Если ни один из CheckBox не помечен то получаю
SQL.text:='SELECT * FROM Certificate WHERE (1 > 0)';
и это означает выборку всей таблицы.
Если пользоатель включает фильтр- то соответственно к этой строке добавляется условие.
Перед AND пробел делать обязательно иначе в строке запроса AND сольется с предыд текстом и будет ошибка.
Согласен, выглядит немного странно, но работает!

Код:
    SQL.text:='SELECT  *  FROM  Certificate WHERE (1 > 0)';
    if CheckBox1.Checked then 
           SQL.add(' AND (CertifType=''просроченные'')');
    if CheckBox2.Checked then 
           SQL.add(Format(' AND (CertifNumber=%d)',[StrToInt(Edit3.Text)]));
    if CheckBox9.Checked then 
           SQL.add(Format(' AND (FormNumber=''%s'')',[Edit4.Text]));
Ответить с цитированием
 


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 21:30.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025