![]() |
|
#4
|
|||
|
|||
![]() Я выкрутился следующим образом
в строке запроса я пишу заведомо истинное условие (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])); |