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

Вниз

Ускорение поиска   Найти похожие ветки 

 
_Andrew_   (2003-06-07 02:05) [0]

Доброй ночи, уважаемые!
Подскажите плз, решение след. проблемы:
есть ДАТАСЕТ с большим набором данных (5000 записей).
Пытаюсь для TEdit сделать нечто MRUListа, для чего пишу:
procedure Form1.Edit1Change(Sender: TObject)
....
if DataSet1.Locate("Name",Edit1.Text,[]) then begin
Edit1.Text := DataSet1.Fields[0].AsString;
....

Все бы ничего, но только на Cel400, при первом Locate происходят страшные томоза :(
Как можно ускорить поиск по ДАТАСЕТУ???


 
Basic ©   (2003-06-07 02:27) [1]

проиндексируй по полю NAME и будет уже ускоренный поиск а не перебор


 
kaif ©   (2003-06-07 03:48) [2]

Если используется Locate в Query, то индексирование не поможет. Нужно просто сделать второй запрос (использовать отдельный компонент для него). Причем в той же транзакции. Это быстро сработает даже без индекса. А Locate очень медленный метод, так как требует fetch всех записей на клиент и ищет перебором этих записей.


 
Alexandr ©   (2003-06-07 09:53) [3]

вот он про первый locate и говорит. Это из-за фетча, ане из-за поиска.
Надо запрос оптимизировать



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

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

Наверх




Память: 0.47 MB
Время: 0.015 c
3-97487
VP
2003-06-05 10:05
2003.06.30
SQL разные форматы данных


11-97567
Alexander
2002-08-19 10:02
2003.06.30
Несколько вопросов и предложений ...


6-97770
Nigger
2003-04-26 13:06
2003.06.30
WinS0ck!


14-97833
DDDD
2003-06-12 09:34
2003.06.30
Microsoft DDK


14-97856
MBo
2003-06-04 17:16
2003.06.30
FAQ ;))