Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2009.11.01;
Скачать: CL | DM;

Вниз

проблемы фильтрации в tado table   Найти похожие ветки 

 
tela ©   (2009-09-06 03:01) [0]

всем доброй ночи! подскажите пожалуйста какможно решить следующую проблему. я использую компонент TADO TABLE, в часности его свойство filter. и все ничего когда фильтрую только по числам:

booktable.Filter:="число = " + QuotedStr(edit1.Text) + " or " + "число = " + QuotedStr(edit2.Text);

но при усложнении опций фильтрации возникают следующие проблемы: компилятор начинает ругаться при обнаружении следующей строки:

booktable.Filter:="число = " + QuotedStr(edit1.Text) + " or " + "число = " + QuotedStr(edit2.Text)
                 +" and "+"нарушитель="+QuotedStr(ComboBox5.Text);

смысл ошибки понятен,хотелось спросить, есть ли в фильтрации -скобки, тоесть действия которые нужно выполнить впервую очередь как в арифметических операциях? Заранее огромное спасибо!


 
СовестьДМ ©   (2009-09-06 10:34) [1]

есть особенности описаны в BOL но ошибка тут непричем


 
tela ©   (2009-09-06 11:32) [2]


> СовестьДМ ©   (06.09.09 10:34) [1]
> есть особенности описаны в BOL но ошибка тут непричем


а в чем тогда дело по вашему?


 
tela ©   (2009-09-06 12:15) [3]

проблема состоит в следующем: если я прописываю опции фильтра

[Code]booktable.Filter:="[число] = " + QuotedStr(edit1.Text) + " or " + "[число] = " + QuotedStr(edit2.Text)+" or "+"[нарушитель]="+QuotedStr(ComboBox5.Text);[/Code]
 
то все работает, только фильтрует не правильно. мне нужно чтобы фильтровало примерно так: (число1 "или" число2) "и" нарушитель.

а оно выдает все данные что указаны в опции, тоесть данные о нарушителе не обращая внимания на числа+ все нарушения за эти числа. а как только я меняю or на and компилятор начинает ругаться


 
sniknik ©   (2009-09-06 12:17) [4]

> а в чем тогда дело по вашему?
в использовании  tadotable не по назначению... (он предназначен исключительно для корзины)
и в замене отбора (select-а) фильтрацией, а это разные по смыслу вещи, хотя и похожи по результирующему виду.

а по ошибке, из хелпа (который ты по идее должен был смотреть в первую очередь)
There is no precedence between AND and OR. Clauses can be grouped within parentheses. However, you cannot group clauses joined by an OR and then join the group to another clause with an AND, like this:
(LastName = "Smith" OR LastName = "Jones") AND FirstName = "John"

Instead, you would construct this filter as
(LastName = "Smith" AND FirstName = "John") OR (LastName = "Jones" AND FirstName = "John")


 
tela ©   (2009-09-09 00:05) [5]

понял, спасибо большое за подсказку!



Страницы: 1 вся ветка

Текущий архив: 2009.11.01;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.017 c
6-1209058825
keymaster
2008-04-24 21:40
2009.11.01
Авторизация на FTP через AD


2-1252291728
Генри
2009-09-07 06:48
2009.11.01
Как добавить запрос к двум таблицам на форму


15-1252016044
Германн
2009-09-04 02:14
2009.11.01
Протокол EtherCat


15-1251865750
TUser
2009-09-02 08:29
2009.11.01
Яндекс-дайрект, я так понимаю, дает контекстную рекламу


15-1252153748
KilkennyCat
2009-09-05 16:29
2009.11.01
Неплохой ролик на тему запрета скайпа и ваще.