![]() |
|
|
#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])); |