|
Тема
|
Търсене с TTable.locate
|
|
Автор | Uchenika (Нерегистриран) |
Публикувано | 09.09.04 09:09 |
|
Използвам за търсене в TTable следното:
TablIzs.Locate('DATEP;KODI;SEQN', VarArrayOf([DynDate,Kodiz, DynS]),[]))
Върви бавно. Две от полетата са ми индексни. Като сложа и третото да е индексно, бързодействието пада още.
Дайте идея за по-бърз механизъм на търсене.
| |
|
А каква ти е базата данни отдолу?
Ти имаш два (или три) отделни индекса, всеки от които е за една колона, така ли? Опитай вместо тях да сложиш един индекс, но по трите полета.
Другият вариант е да използваш TQuery вместо TTable и да си селектваш направо от базата търсените записи: select * from tablizs where datep = :datep and kodi = :kodi and seqn = :seqn...
| |
Тема
|
Re: Търсене с TTable.locate
[re: andrew_nikoloff]
|
|
Автор | Учeниka (Нерегистриран) |
Публикувано | 09.09.04 09:55 |
|
Използвам Pradox.
Опитах с TQuery и наистина хукна два пъти по-бързо. За индексиране едновременно с трите полета също го пробвах, но не даде задоволителен рзултат. Затова питам за нещо качествено различно, което може би изпускам.
| |
Тема
|
Re: Търсене с TTable.locate
[re: Учeниka]
|
|
Автор |
ess (мечтател) |
Публикувано | 09.09.04 10:48 |
|
Като си направиш индекс по трите полета едновременно, ползвай IndexName & FindKey. Ето така:
Table1.IndexName := 'datep_kodi_seqn';
if Table1.FindKey([EncodeDate(2001,1,1), 'kod1', 1]) then begin
ShowMessage('Found!');
end;
---
...и аз пиша на кирилица!
| |
Тема
|
Най-бързо е с TQuery
[re: ess]
|
|
Автор | Учeниka (Нерегистриран) |
Публикувано | 10.09.04 13:31 |
|
Експериментирах с всички възможности.
Най-бързо е с TQuery.
По-бавно е с две независими индексни полета от трите, които използвам.
При три независими или трите обединени, скоростта на търсене е най-малка.
| |
Тема
|
Re: Най-бързо е с TQuery
[re: Учeниka]
|
|
Автор |
NDeu (динозавър) |
Публикувано | 11.09.04 11:23 |
|
Търсене с Locate не е желателен за големи обеми защото фечва всички записи на датасета до намиране на търсения на клиента.
Редактирано от NDeu на 11.09.04 11:26.
| |
|
|
|
|