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

Вниз

Как отфильтровать таблицу по указанному полю (MS Access + ADO)   Найти похожие ветки 

 
BlackCat ©   (2003-12-23 04:17) [0]

Доброго времени суток, уважаемые мастера!
Возникла проблема такого характера. Есть на форме AdoQuery, DBGrid и Edit.
Как можно сделать так, чтобы при вводе букв в Edit в DBGrid"e оставались только те записи, которые начинаются с этих букв.
Например вводишь "а", а в гриде остаются записи, начинающиеся с "а", "аб" - то начинающиеся с "аб".

заранее благодарен.


 
chtr ©   (2003-12-23 08:13) [1]

Использовать TEdit.onkeypress и TADOQuery.filter или параметры в запросе.


 
Sens ©   (2003-12-23 08:33) [2]

DM - ДатаМодуль;
Sel_Mat - TQuery; (вместо TQuery может быть ADODataSet, только тогда вместо DM.Sel_Mat.SQL. должно быть DM.Sel_Mat.CommandText.)
S_DOS - начало строки, по которому делаем фильтр/выборку ;

DM.Sel_Mat.Active:=1=0;
DM.Sel_Mat.SQL.Clear;
DM.Sel_Mat.SQL.Add("select * from par_NC where Name LIKE :P_Name");
DM.Sel_Mat.ParamByName("P_Name").AsString:="S_DOS+"%";
DM.Sel_Mat.Active:=1=1;


 
Sens ©   (2003-12-23 08:36) [3]

Опс. ошибка в тексте.
DM.Sel_Mat.ParamByName("P_Name").AsString:= S_DOS+"%";


 
Silver Alex ©   (2003-12-23 10:05) [4]

на событие OnFilterRecord

procedure TForm1.ADODataSet1FilterRecord(DataSet: TDataSet;
var Accept: Boolean);
begin
Accept:=((pos(AnsiUpperCase( Edit1.Text), AnsiUpperCase(DataSet.FieldByName("name").AsString))=1) or
(Edit1.Text=EmptyStr)) ;
end;

procedure TForm1.Edit1Change(Sender: TObject);
begin
ADODataSet1.Filtered:=false;
ADODataSet1.Filtered:=true;
end;



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

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

Наверх




Память: 0.47 MB
Время: 0.037 c
3-63038
Nobody2002
2003-12-22 10:14
2004.01.20
Проблема с кодировкой


4-63448
OlegV
2003-11-13 15:37
2004.01.20
Удаление выполняющегося EXE файла


7-63414
FireMan_Alexey
2003-11-05 14:53
2004.01.20
Как можно убрать прогу из списка процессов?


7-63425
zoltan
2003-11-02 19:38
2004.01.20
ТРЕЙ


3-63019
Trad
2003-12-22 06:47
2004.01.20
прямая запись в БД