Главная страница
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.038 c
2-1146131742
eclipse
2006-04-27 13:55
2006.05.14
Передача данных между формами


8-1134812696
Фео
2005-12-17 12:44
2006.05.14
Драм-машина


2-1146131452
Olga_Detka
2006-04-27 13:50
2006.05.14
помогите мне решить задачу, непоцму сама как это сделать


15-1145420452
ORMADA
2006-04-19 08:20
2006.05.14
Определение программы упаковки файла


2-1145801266
vz
2006-04-23 18:07
2006.05.14
Таймер