Главная страница
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.035 c
14-1086723074
Petr V. Abramov
2004-06-08 23:31
2004.06.27
Текст лицензии на FIBPlus для юр.лиц и для физ лиц.


1-1086951849
Ivolg
2004-06-11 15:04
2004.06.27
Копирование и Удаление


10-1013876230
nikols
2002-02-22 12:16
2004.06.27
Name service в VisiBroker?


3-1085736543
BPK
2004-05-28 13:29
2004.06.27
Функция с произвольной таблицей на выходе


3-1085857779
DIS
2004-05-29 23:09
2004.06.27
в запросе условие WHERE