Russian Qt Forum

Программирование => Базы данных => Тема начата: danius от Февраль 10, 2006, 07:42



Название: Контекстный поиск
Отправлено: 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
Я тебе примерно тоже вверху написал! про промежуточную таблицу