Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2006.05.14;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.012 c
2-1145914797
Slinne
2006-04-25 01:39
2006.05.14
Помогите написать простенькую процедуру (Delphi).


2-1145693535
Ell
2006-04-22 12:12
2006.05.14
int64 в цикле


2-1145705208
FunkyByte
2006-04-22 15:26
2006.05.14
Несколько вопросов про потоки и сообщения


15-1145366258
oldman
2006-04-18 17:17
2006.05.14
Что не видел ни одного поста по поводу...


2-1146083600
chai
2006-04-27 00:33
2006.05.14
Работа с поинтерами: корректен ли этот код?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский