| 
| 
 | Вопрос # 5 025/ вопрос решён / | 
 |  Приветствую, уважаемые эксперты!
 Подскажите пожалуйста как мне организовать поиск по базе DBF при помощи компонента TTABLE.
 
 
 
 
 P.S. Я новичёк в программировании, поэтому не пинать! :)
 Приложение:Переключить в обычный режим  Table1.IndexFieldNames:='KOD';Table1.SetKey(); Table1.GotoKey(); Edit2.Text:=Table1.FieldByName('NAZVANIE').AsString; 
Примечание #1 (17 февраля 2011, 10:56): Интересует именно метод:Table1.SetKey();
 Table1.GotoKey();
 
 
|  |   Вопрос задал: NSS (статус: Посетитель)Вопрос отправлен: 17 февраля 2011, 09:45
 Состояние вопроса: решён, ответов: 1.
 |  Ответ #1. Отвечает эксперт: Вадим К Здравствуйте, NSS!метод SetKey переводит таблицу в режим поиска. После этого можно задать поле для поиска. Ну а GotoKey собственно делает сам поиск. У этого метода есть одна особенность - по данному полю должен быть настроен индекс. Иначе ничего не получится. Вот тут есть большая статья, там это описано.
 
 А ещё для поиска есть методы Locate и Lookup. Описаны здесь.
 
 Также поиск можно и ручками организовать, хотя это и некрасиво и малопроизводительно, но в некоторых случаях может помочь.
 
|  | Ответ отправил: Вадим К (статус: Академик)Время отправки: 17 февраля 2011, 12:33
 Оценка за ответ: 5
 |  
 Мини-форум вопросаВсего сообщений: 3; последнее сообщение — 18 февраля 2011, 14:40; участников в обсуждении: 2. 
|   | 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 (статус: Посетитель), 18 февраля 2011, 14:40 [#3]:Код и был с самого начала, а раз с вопросом значит что-то с ним не то. 
 Нда..... Копнул по ссылке и зарылся по уши ))))).
 Спасибо за подсказки и ссылки, разобрался, все заработало.
 |  18 февраля 2011, 14:43: Статус вопроса изменён на решённый (изменил автор вопроса — NSS) Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте. |