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

Вниз

Проблема с отображением числа записей отфильтрованной таблицы   Найти похожие ветки 

 
Мефодий   (2003-08-14 16:45) [0]

Есть DBF таблица Table1.
На Form1 разместил DBGrid 1, Edit1 и Label1.
Прописаны следующие события.

procedure TForm1.Edit1Change(Sender: TObject);
begin
with Table1 do
begin
if Length(Edit1.Text) = 0 then
begin
Filtered := False;
Label1.Caption := IntToStr(RecordCount);
First;
Exit;
end;
Filtered := True;
Label1.Caption := IntToStr(RecordCount);
end;
end;

procedure TDM.Table1FilterRecord(DataSet: TDataSet; var Accept: Boolean);
begin
Accept := Pos(Edit1.Text,Table1.FieldByName("A").AsString)) > 0
end;

При первом вхождении в программу и начале набора текста в Edit1 все нормально, т.е. число записей в Label1.Caption последовательно уменьшается и соответствует числу записей, отображаемых в DBGrid1. Когда же нажимаю Backspace, число отображаемых в DBGrid1 записей, естественно, увеличивается, однако Label1.Caption свое значение не меняет. Более того, если при Length(Edit1.Text) = 0 оно правильно отображает общее число записей неотфильтрованной таблицы, то при повторном наборе текста вообще начинает показывать ерунду. В чем тут дело ? Если кто встречался с такой проблемой прошу отозваться. Заранее благодарен.


 
Anatoly Podgoretsky ©   (2003-08-14 16:58) [1]

Значит оно изменяется после срабатывания данного обработчика
попробуй
Filtered := False;
Filtered := True;
может поможет


 
Мефодий   (2003-08-15 09:42) [2]

Пробовал, не помогает !


 
Johnmen ©   (2003-08-15 10:05) [3]

Как пробовал ? Код ?


 
Anatoly Podgoretsky ©   (2003-08-15 10:08) [4]

Еще иногда надо перемещеие, First


 
Мефодий   (2003-08-15 12:23) [5]

>>Как пробовал ? Код ?

procedure TForm1.Edit1Change(Sender: TObject);
begin
with Table1 do
begin
Filtered := False;
if Length(Edit1.Text) = 0 then
begin
Label1.Caption := IntToStr(RecordCount);
First;
Exit;
end;
Filtered := True;
Label1.Caption := IntToStr(RecordCount);
end;
end;

Не помогает и First.


 
Johnmen ©   (2003-08-15 12:26) [6]

А он и не поможет. Если сразу то Exit. :)))


 
Мефодий   (2003-08-15 20:51) [7]

>> А он и не поможет. Если сразу то Exit

Exit только в случае пустой строки.



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

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

Наверх




Память: 0.48 MB
Время: 0.018 c
3-24390
FREEMAN
2003-08-15 12:15
2003.09.08
Hint в DBgrid


8-24569
_Alex_
2003-05-06 20:48
2003.09.08
рисование на Canvas не повреждая фон


6-24603
qpwoeiruty
2003-07-02 16:50
2003.09.08
Количество получателей в поле TO:


14-24664
Kost
2003-08-20 15:04
2003.09.08
TextOut


1-24438
shark
2003-08-25 16:14
2003.09.08
Вызов функции из функции