Главная страница
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.026 c
8-41759
pasha676
2003-07-08 15:57
2003.11.13
Front с прозрачным фоном на Canvas-e


4-42301
ruslan_as
2003-09-08 12:42
2003.11.13
Занести пароль в окно другого приложения


14-41910
Кот Бегемот
2003-10-21 12:51
2003.11.13
Кот на повороте стал буксовать и срываться в занос...


3-41071
Kinder
2003-10-19 22:07
2003.11.13
как удалить строку из таблицы


1-41676
Igit
2003-10-24 20:16
2003.11.13
pascal and assembler