Главная страница
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.02 c
1-97673
Far
2003-06-17 14:05
2003.06.30
Заголовок формы


14-97804
StarCon
2003-06-10 12:47
2003.06.30
а не пора ли перейти на Delphi 7


1-97686
vv_fran
2003-06-17 15:03
2003.06.30
Как очистить буфер клавиатуры?


14-97877
Fantasist.
2003-06-11 19:39
2003.06.30
Буддисты


3-97546
Alexey
2003-06-06 18:20
2003.06.30
Индексация