Тема: SQL Запросы
Показать сообщение отдельно
  #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]));
Ответить с цитированием