Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 5 025

/ вопрос решён /

Приветствую, уважаемые эксперты!

Подскажите пожалуйста как мне организовать поиск по базе DBF при помощи компонента TTABLE.




P.S. Я новичёк в программировании, поэтому не пинать! :)

Приложение:
  1.  
  2. Table1.IndexFieldNames:='KOD';
  3. Table1.SetKey();
  4.  
  5. Table1.GotoKey();
  6.  
  7. Edit2.Text:=Table1.FieldByName('NAZVANIE').AsString;
  8.  


Примечание #1 (17 февраля 2011, 10:56):
Интересует именно метод:
Table1.SetKey();
Table1.GotoKey();

NSS Вопрос решён, но можно продолжить его обсуждение в мини-форуме

Вопрос задал: NSS (статус: Посетитель)
Вопрос отправлен: 17 февраля 2011, 09:45
Состояние вопроса: решён, ответов: 1.

Ответ #1. Отвечает эксперт: Вадим К

Здравствуйте, NSS!
метод SetKey переводит таблицу в режим поиска. После этого можно задать поле для поиска. Ну а GotoKey собственно делает сам поиск. У этого метода есть одна особенность - по данному полю должен быть настроен индекс. Иначе ничего не получится. Вот тут есть большая статья, там это описано.

А ещё для поиска есть методы Locate и Lookup. Описаны здесь.

Также поиск можно и ручками организовать, хотя это и некрасиво и малопроизводительно, но в некоторых случаях может помочь.

Ответ отправил: Вадим К (статус: Академик)
Время отправки: 17 февраля 2011, 12:33
Оценка за ответ: 5


Мини-форум вопроса

Всего сообщений: 3; последнее сообщение — 18 февраля 2011, 14:40; участников в обсуждении: 2.
NSS

NSS (статус: Посетитель), 17 февраля 2011, 18:02 [#1]:

Методы Locate и Lookup у меня работают.
Мне нужны методы SetKey и GotoKey. По приведенной первой ссылке описание совпадает с тем, что есть у меня. Я вначале привел текст программы, который не работает, пишет что нужно проиндексировать таблицу. А как это сделать я никак не пойму.
Мне казалось, что Table1.IndexFieldNames:='KOD'; это и есть индексация - оказалось что нет(.
Вадим К

Вадим К (статус: Академик), 18 февраля 2011, 10:50 [#2]:

Вот нужно сразу и писать, что код есть, но не хочет он работать.

строка Table1.IndexFieldNames:='KOD'; это лишь подсказка TTable, что у Вас есть индекс. Табличку ведь в DataBase Desktop делали? вот там есть и возможность указать, что нужно сделать индекс по полю. Поищите, а ссылка в помощь
Галочка "подтверждения прочтения" - вселенское зло.
NSS

NSS (статус: Посетитель), 18 февраля 2011, 14:40 [#3]:

Код и был с самого начала, а раз с вопросом значит что-то с ним не то.

Нда..... Копнул по ссылке и зарылся по уши ))))).
Спасибо за подсказки и ссылки, разобрался, все заработало.

18 февраля 2011, 14:43: Статус вопроса изменён на решённый (изменил автор вопроса — NSS)

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 22 февраля 2025, 11:44
Выполнено за 0.02 сек.