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

Вниз

Последующий поиск   Найти похожие ветки 

 
abhtr   (2006-03-22 09:17) [0]

Как осуществить последующий поиск записей по заданному вначале ключу. Т.е. первую запись нахожу по
tblDBF.Locate(sFindField,sFindValue,[loCaseInsensitive, loPartialKey]);
А как найти следующую запись? После этой.


 
Megabyte ©   (2006-03-22 13:14) [1]

Могу ошибаться(нет возможности проверить), но попробуй tblDBF.findnext


 
sniknik ©   (2006-03-22 13:24) [2]

> но попробуй tblDBF.findnext
если в том что он использует есть findnext..., то использовать его надо после findfirst а не Locate. вообще в справке должно быть по используемому движку.


 
Sergey13 ©   (2006-03-22 13:31) [3]

2abhtr   (22.03.06 09:17)
>А как найти следующую запись?
Универсально  - перебор в цикле со сравнением с эталоном. Работает всегда и везде.


 
vovnuke ©   (2006-03-22 15:00) [4]

А для каких целей? А то ведь можно отфильтровать по этому ключу.


 
abhtr   (2006-03-22 15:12) [5]

Сейчас так и делаю - отфильтровываю. Но при некоторых работах удобнее, чтобы поиск был как в Far-е. Поэтому и хочеться реализовать именно такой способ поиска. С findnext не пробовал. Кстати, кто-нибудь знает, какой алгоритм поиска у locate. Перебором? Или как-то иначе? Без индекса.


 
Sergey13 ©   (2006-03-22 15:16) [6]

2[5] abhtr   (22.03.06 15:12)
>Кстати, кто-нибудь знает, какой алгоритм поиска у locate.
Так любой поиск идет перебором. Важно что и как перебирать. 8-)


 
Lexer ©   (2006-03-22 15:38) [7]

abhtr   (22.03.06 15:12) [5]
>Кстати, кто-нибудь знает, какой алгоритм поиска у locate.


Вот небольшая вырезка из DBTables, здесь можно только догадываться (т.к. нет bde.pas), но помоему накладывается фильтр, и активизируется первая строка, после чего фильтр убирается.

DbiActivateFilter(FHandle, Filter);
Status := DbiGetNextRecord(FHandle, dbiNoLock, Buffer, nil);
DbiDropFilter(FHandle, Filter);
Result := Status = DBIERR_NONE;


 
Виталий Панасенко   (2006-03-22 15:39) [8]

select с нужным условием - и тогда все данные будут те, что нужно



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

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

Наверх




Память: 0.48 MB
Время: 0.048 c
15-1145262848
boriskb
2006-04-17 12:34
2006.05.14
Прошу оценить сайт :)


15-1145291560
Yanis
2006-04-17 20:32
2006.05.14
ICQ не работает


2-1145952826
Pretender
2006-04-25 12:13
2006.05.14
Поиск заданного фрагмента в файле


2-1145789779
sysop
2006-04-23 14:56
2006.05.14
Выравнивание строки


2-1145876145
accinctus
2006-04-24 14:55
2006.05.14
свойства файлов