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

Вниз

Нужна помощь по Filter.   Найти похожие ветки 

 
Jet ©   (2004-05-30 12:47) [0]

Есть таблица .dbf (Fox)
Есть переменная fam, которая принимает разные значения.
Например: "Петро","Ивано","Сидор", т.е. первые пять букв фамилии.
Нужно составить фильтр по этой переменной для поля Fname таблицы.
Что-то вроде этого:
Form1.Table.Filter := "Table.Fname like fam";
--
Но как правильно сделать фильтр?


 
YurikGl ©   (2004-05-30 12:54) [1]

В  хелпе нашел

Memo LIKE "%filters%"

Тебе нужно
Имя поля like "Ивано%"


 
Jet ©   (2004-05-30 12:57) [2]

Мне нужно что-то типа такого:
Form1.Table.Filter := "Table.Fname like fam + "%"";
Но как приваильно оформить фильтр?
Переменная fam принимает разные значения и явно указывать в фильтре их не получится.


 
YurikGl ©   (2004-05-30 13:01) [3]

Form1.Table.Filter := "имя поля таблицы like "+#39+fam+"%"+#39;

fam должно быть строкой.


 
Anatoly Podgoretsky ©   (2004-05-30 13:14) [4]

OnFilter Record не имеет ограничений


 
YurikGl ©   (2004-05-30 13:30) [5]


> Anatoly Podgoretsky ©   (30.05.04 13:14) [4]


Не понял...


 
Jet ©   (2004-05-30 13:33) [6]

Фильтр оформлен не правильно, что-то с кавычками не так.
А как использовать фильтр по двум переменным и двум полям?
--
Form1.Table.Filter := "(Fname like "+#39+fam+"%"+#39) and (Lname like "+#39+fam+"%"+#39); ???
--
Только оформлен не правильно синтаксически.


 
YurikGl ©   (2004-05-30 13:35) [7]

Попробуй
Form1.Table.Filter := "(Fname like "+#39+fam+"%"+#39+") and (Lname like "+#39+fam+"%"+#39);


 
Jet ©   (2004-05-30 13:36) [8]

Попробую, сейчас возможности нет, базы все на работе.


 
YurikGl ©   (2004-05-30 13:39) [9]

Дык создай быстренько на access-е и проверь. А то опять вопросы появятся.


 
Vlad ©   (2004-05-30 13:51) [10]


> YurikGl ©   (30.05.04 13:35) [7]

Я конечно не большой спец по фильтрам, но с каких это пор в выражинии для фильтра позволяется like % писать ?
Извиняюсь, но по-моему твой пример - это бред.

property Filter: String;

Specifies the text of the current filter for a dataset.

Description

Use Filter to specify a dataset filter. When filtering is applied to a dataset, only those records that meet a filter’s conditions are available to an application. Filter contains the string that describes the filter condition. For example, the following filter condition displays only those records where the State field is "CA" or "MA":

State = "CA" or State = "MA"

To filter strings bases on partial comparisons, use an asterisk as a wildcard. For example:

State = "M*"

Note: Applications can set Filter at runtime to change the filtering condition for a dataset at (for example, in response to user input).


 
Jet ©   (2004-05-30 13:53) [11]

> Vlad

Так а переменные тогда как использовать? Явно указывать в фильтре нет возможности.


 
Vlad ©   (2004-05-30 14:01) [12]


> Jet ©   (30.05.04 13:53) [11]


> Так а переменные тогда как использовать? Явно указывать
> в фильтре нет возможности.

Почему нет ?
я же привел справку, читай внимательнее:

Note: Applications can set Filter at runtime to change the filtering condition for a dataset at (for example, in response to user input).


 
YurikGl ©   (2004-05-30 14:08) [13]

Vlad ©   (30.05.04 13:51) [10]

Если я не ошибаюсь, фильтр обрабатывается СУБД.

Одна и та же строка
ADODataSetSborki.Filter:="naimenovan like"+#39+"%1%"+#39;

в Access не катит а в IB прошла.

З.Ы. Если я ничего не накосячил, когда проверял


 
sniknik ©   (2004-05-30 14:16) [14]

Vlad ©   (30.05.04 13:51) [10]
> Я конечно не большой спец по фильтрам, но с каких это пор в выражинии для фильтра позволяется like % писать ?
> Извиняюсь, но по-моему твой пример - это бред.
в ADO можно, именно с like.

YurikGl ©   (30.05.04 14:08) [13]
пробел пропустил,
ADODataSetSborki.Filter:="naimenovan like "+#39+"%1%"+#39;
аксесс тоже такое берет и MSSQL


 
YurikGl ©   (2004-05-30 14:19) [15]

sniknik ©   (30.05.04 14:16) [14]

Странно, у меня без пробела сработало.

В access-е теперь тоже получилось. :)


 
Vlad ©   (2004-05-30 14:39) [16]

Возможно, но я имел ввиду БДЕ, автор движок ведь не уточнял


 
Anatoly Podgoretsky ©   (2004-05-30 14:42) [17]

Бессмысленно обсуждать формат фильтра в отрыве от движка


 
Jet ©   (2004-05-30 14:52) [18]

> ADODataSetSborki.Filter:="naimenovan like "+#39+"%1%"+#39;

Что значит %1%?

Можно ли использовать фильтр таким образом?:

Form1.Table.Filter := "(Fname like "+#39+fam+"%"+#39+") and (Lname like "+#39+name+"%"+#39);

Где fam и name - переменные, которые принимают разные значения, Fname и Lanme - поля таблицы.


 
sniknik ©   (2004-05-30 15:18) [19]

Jet ©   (30.05.04 14:52) [18]
прочитай 100 раз.
-> Anatoly Podgoretsky ©   (30.05.04 14:42) [17]
не поможет, читай еще столько же в слух и с выражением.


 
YurikGl ©   (2004-05-30 15:28) [20]


> Что значит %1%?


Значит выбрать записи у в которых в соответствующем поле есть символ "1"


> Можно ли использовать фильтр таким образом?:

А ты попробуй...



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

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

Наверх




Память: 0.51 MB
Время: 0.052 c
3-1085639743
lightix
2004-05-27 10:35
2004.06.27
Вызов хранимой процедуры в ODAC


8-1081841509
Max003
2004-04-13 11:31
2004.06.27
Как узнать установлен-ли FLASH player для веб броузера?


14-1086620797
Sana
2004-06-07 19:06
2004.06.27
У шефа слетела электронная записная книжка...


3-1085756667
Bizons
2004-05-28 19:04
2004.06.27
GEN_ID() в IB6


14-1086514388
SilPoc
2004-06-06 13:33
2004.06.27
Служба сообщений на службе у спамеров