Главная страница
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.016 c
14-97879
Видеоман
2003-06-09 23:08
2003.06.30
Как склеить mpg-файлы?


1-97720
QUE
2003-06-18 14:00
2003.06.30
Как избавиться от пунктирных линий при отрисовке ячеек StringGrid


3-97522
Виталий Панасенко
2003-06-06 10:20
2003.06.30
LocalSQL


3-97501
Igor Mish
2003-06-05 10:14
2003.06.30
Шрифты в ShowMessage


7-97897
max2057
2003-04-14 17:41
2003.06.30
инструкция 0х0000000 обратилась по адресу 0х0000000