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

Вниз

Как организовать циклический поиск по таблице?   Найти похожие ветки 

 
Anics   (2004-03-02 10:32) [0]

Пусть есть таблица сотрудников, и там 10 человек с фамилией "Иванов". Как можно организовать поиск таким образом, чтобы при первом поиске позиционировался первый "Иванов", при втором - второй "Иванов" и так далее по циклу?


 
Alex_Bredin ©   (2004-03-02 10:35) [1]

создайте индекс по этому полю


 
Anics   (2004-03-02 10:36) [2]

Индекс существует, что дальше?


 
malkolinge ©   (2004-03-02 10:39) [3]

Если на клиенте - наложи фильтр. Name = "Иванов".


 
VAleksey ©   (2004-03-02 10:46) [4]

1) Навигация по условиям фильтра в неотфильтрованном НД. DataSet.FindFirst, DataSet.FindNext. Фильтр можно установить с помощью св-в Filter или события OnFilterRecord - DataSet - a. (Советую OnFilterRecord)
2) Сделать запрос и получить списко идентификаторов (ID) для всех Ивановых в таблице. Затем простой Locate по значениям из этого списка.
3) Взять dbGridEh где реадизована эта возможность.


 
Voland2000   (2004-03-02 12:58) [5]

Не знаю как вы, а я сделал по своему:
1)Проходим каждую запись таблицы.
2)Функцией pos() ищем нужную строку.


 
SPIRIT ©   (2004-03-02 13:01) [6]


> Voland2000   (02.03.04 12:58) [5]

и по времени это раз в 5 долльше чем [4] .


 
Anatoly Podgoretsky ©   (2004-03-02 13:11) [7]

Anics   (02.03.04 10:36) [2]
Дальше два оптимальных варианта
1. фильтр по фамилии
2. Активируем индекс, Locate и далее последовательный поиск (Next) пока фамилия равна.
3. неоптимальный вариант, Locate и далее последовательный поиск до конца набора с проверкой на совпадение


 
Alex_Bredin ©   (2004-03-02 13:35) [8]

в добавление к

> Anatoly Podgoretsky ©   (02.03.04 13:11) [7]


Лучше использовать SetKey,GotoNearest вместо Locate(для индексированных полей)


 
Anatoly Podgoretsky ©   (2004-03-02 13:36) [9]

Или GotoNearest или FindNearest в зависимости от индекса


 
Соловьев ©   (2004-03-02 13:46) [10]

http://delphimaster.net/view/3-1076933565/
посмотреть то что я предложил



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

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

Наверх




Память: 0.48 MB
Время: 0.023 c
7-1074601161
Application
2004-01-20 15:19
2004.04.04
Процесс и память


14-1078927826
Yurchik
2004-03-10 17:10
2004.04.04
Нужен uses CommonFunc.pas(.dcu). Помогите плиииссс.


1-1079585912
-= Evgeney =-
2004-03-18 07:58
2004.04.04
Реестр


8-1070302395
DeScriptor
2003-12-01 21:13
2004.04.04
Разрешение файла AVI


14-1078469470
Sergey_Masloff
2004-03-05 09:51
2004.04.04
Хорошая книга по полевой хирургии для начинающего