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

Вниз

TADOQuery и ListView   Найти похожие ветки 

 
Petr   (2003-10-23 09:22) [0]

Для вывода записей базы данных я использую TListView (TDBGrid мне не совем подходит)

TListView я заполняю так:

procedure ReadData;
var
I: Integer;
ListItem: TListItem;
begin
ADOQuery.Open;
if ADOQuery.RecordCount > 0 then
begin
ADOQuery.First;
ListView.AllocBy := ADOQuery.Record
ListView.Items.BeginUpdate;
while not ADOQuery.Eof do
begin
ListItem := ListView.Items.Add;
ListItem.Caption := ADOQuery.Fields[0].AsString;
for I := 1 to ADOQuery.FieldCount - 1 do
ListItem.SubItems.Add(ADOQuery.SubItems.Add(ADOQuery.Fields[I].AsString);
ADOQuery.Next;
end;
ListView.Items.EndUpdate;
end;
ADOQuery.Close;
end;


Записей полей в таблице около 20-25 и записей около 1000. Получается очень долго, а DBGrid отображает записи достаточно быстро. Что не так? И чем отличается FindNext от Next, из справки я ничего не понял так как английский плохо знаю.


 
Кулюкин Олег ©   (2003-10-23 09:26) [1]

Можно перевести ListView в виртуальный режим, а данные из TADOQuery вычитывать в список объектов.
Работает быстрок и на 10000 записей.

Виртуальный режим есть в демках.



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

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

Наверх




Память: 0.46 MB
Время: 0.041 c
6-41803
nefrit
2003-09-15 22:26
2003.11.13
Netbios


1-41640
Чайник Д
2003-10-25 23:06
2003.11.13
Как быстрее всего зделать скриншорт


1-41525
Stas
2003-10-28 11:07
2003.11.13
TCanvas


6-41856
Stas
2003-09-09 15:49
2003.11.13
Почему не работает динамически созданный TNMSTRMServ ?


1-41385
kavlad
2003-10-30 12:28
2003.11.13
Все (почти) пропало