Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 21.01.2009, 20:38
Аватар для Yurk@
Yurk@ Yurk@ вне форума
Специалист
 
Регистрация: 07.09.2007
Адрес: Украина, г. Днепропетровск
Сообщения: 892
Версия Delphi: 7 + ОгнеПтица
Репутация: выкл
Вопрос Filter в IBQuery

Доброго времени суток ... столкнулся вот с такой проблемой:
есть БД на Firebird ... выбираю данные из базы с помощью запроса (IBQuery) ... кроме этого мне нужно организовать поиск по выбраным записям с максимальной скоростью ... раньше (в локальных БД) для этой цели делал Filter и этого было вполне достаточно ... в IBQuery эта функция почему-то не работает. Пробовал сделать через OnFilterRecord, но там запись находится только при полном написании введенного значени, а мне нужно чтобы записи фильтровались при каждом нажатии буквы.
Может кто-то подскажет как мне обойти эту проблему

P.S. Компоненты FIBPlus не предлагать
__________________
Поживу - увижу, Доживу - узнаю, Выживу - учту.
[P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз
Ответить с цитированием
  #2  
Старый 21.01.2009, 20:45
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Код обраболтчика события сюда выложи.
Ответить с цитированием
  #3  
Старый 21.01.2009, 22:00
Аватар для Yurk@
Yurk@ Yurk@ вне форума
Специалист
 
Регистрация: 07.09.2007
Адрес: Украина, г. Днепропетровск
Сообщения: 892
Версия Delphi: 7 + ОгнеПтица
Репутация: выкл
Восклицание

Для Firebird\Interbase делаю так:
Код:
procedure TForm1.QFilterRecord(DataSet: TDataSet; var Accept: Boolean);
begin
Accept:=(Q.FieldByName('SPEC').AsString='строка');
end;

procedure TForm1.Edit1Change(Sender: TObject);
begin
Q.Filtered:=True;
end;
Q - это IBQuery.

Для локальной БД раньше делал так:
Код:
procedure TForm1.Edit1Change(Sender: TObject);
begin
eQuery.Filter:='Icrtf_sht_num = '''+Ed_Pak.Text+'*''';
eQuery.Filtered:=True;
end;
Для IBQuery такая обработка почему-то не подходит и записи он не фильтрирует ... а нужно чтобы он это делал по принципу аналогичному как для локальной БД
__________________
Поживу - увижу, Доживу - узнаю, Выживу - учту.
[P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз
Ответить с цитированием
  #4  
Старый 21.01.2009, 22:09
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,015
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

ага, а самому сравнивать по частям слабо?

Код:
procedure TForm1.QFilterRecord(DataSet: TDataSet; var Accept: Boolean);
begin
  // Начинается с...  
  Accept:= Pos(Edit1.Text,DataSet.FieldByName('SPEC').AsString) = 1;
end;
Ответить с цитированием
  #5  
Старый 21.01.2009, 22:22
Аватар для Yurk@
Yurk@ Yurk@ вне форума
Специалист
 
Регистрация: 07.09.2007
Адрес: Украина, г. Днепропетровск
Сообщения: 892
Версия Delphi: 7 + ОгнеПтица
Репутация: выкл
По умолчанию

пасибо ... я был так близок к ответу:
Код:
 Accept:= Pos(Edit1.Text,DataSet.FieldByName('SPEC').AsString) <> 0; 

слегка "не докопал"
__________________
Поживу - увижу, Доживу - узнаю, Выживу - учту.
[P.S.]->Выражая благодарность за помощь - Вы получаете шанс на помощь в следующий раз

Последний раз редактировалось Yurk@, 21.01.2009 в 22:24.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 16:12.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter