Название: Контекстный поиск Отправлено: danius от Февраль 10, 2006, 07:42 Кто нибудь сталкивался с такой задачей: реляционная база данных, несколько полей (пусть текстовых). Необходимо выполнить контекстный поиск по всем полям сразу.
Первое, что приходит в голову объединить все поля в одно и выполнять поиск в нём, но imho большие затраты, т.к. база довольно большая (~500 ты. записей, ~10 полей). Если кто-то уже решал такую проблему подскажите. Спасибо. Название: Контекстный поиск Отправлено: Admin от Февраль 10, 2006, 09:13 Я в свое время так и сделал. Делал временную таблицу и туда все сваливал и и искал.
Проблема еще в принципе пойска. Что нужно искать? Если 1 слово, то можно обойтись LIKE по каждому полю. А если комбинациями, типа boots AND girls , причем слова могут быть в разных колонках, то тут только сваливать в 1 таблицу надо. Название: Контекстный поиск Отправлено: danius от Февраль 12, 2006, 07:49 Я думал сделать примерно как поиск в Winamp Library.
У меня в базе хранятся данные на граждан (фио, д.р., прописка и доп.инфа), и поиск должен осуществляеться примерно так: Иван Иванов, Иванов Иван, Иван 1985, Иванов пр.Ленина и т.п. Если использовать LIKE, то надо все поля индексировать, тоже дорого. Может можно придумать что? Название: Контекстный поиск Отправлено: Admin от Февраль 12, 2006, 11:49 Я могу ошибатся но Like ищет кажется только по полю!
Можно сделать так: Форма с галочками. Типа: Фамилия : Иванов Имя: Отчество: Иванович Год: И не давать пользователю вводить строку типа Иван 1985. Тогда поиск как у тебя делается легко! Название: Контекстный поиск Отправлено: danius от Февраль 12, 2006, 14:14 IMHO галочки в принципе не нужны, просто пустые поля не искать.
:idea: В принципе можно все параметры для поиска (фио, г.р., адрес и т.п.) собрать в одну таблицу (3) и используя связь многие-ко-многим (с использованием промежуточной таблицы (2)) на первоначальную таблицу(1). Тогда действуем так: ищем в (3) затем через (2) находим кучу записей в (1) и уже из них выбираем дальше :shock:. Только нам оно надо такой геморрой? Уж лучше с формой, хотя пользователю было бы удобнее, в программе толко таблица и поле ввода. Название: Контекстный поиск Отправлено: Admin от Февраль 13, 2006, 12:21 Я тебе примерно тоже вверху написал! про промежуточную таблицу
|