Russian Qt Forum
Ноябрь 22, 2024, 21:36 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: Контекстный поиск  (Прочитано 7902 раз)
danius
Гость
« : Февраль 10, 2006, 07:42 »

Кто нибудь сталкивался с такой задачей: реляционная база данных, несколько полей (пусть текстовых). Необходимо выполнить контекстный поиск по всем полям сразу.
    Первое, что приходит в голову объединить все поля в одно и выполнять поиск в нём, но imho большие затраты, т.к. база довольно большая (~500 ты. записей, ~10 полей).
    Если кто-то уже решал такую проблему подскажите. Спасибо.
Записан
Admin
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 1988



Просмотр профиля
« Ответ #1 : Февраль 10, 2006, 09:13 »

Я в свое время так и сделал.  Делал временную таблицу и туда все сваливал и и искал.

Проблема еще в принципе пойска. Что нужно искать?

Если 1 слово, то можно обойтись LIKE по каждому полю.
А если комбинациями, типа boots AND girls , причем слова могут быть в разных колонках, то тут только сваливать в 1 таблицу надо.
Записан
danius
Гость
« Ответ #2 : Февраль 12, 2006, 07:49 »

Я думал сделать примерно как поиск в Winamp Library.
  У меня в базе хранятся данные на граждан (фио, д.р., прописка и доп.инфа), и поиск должен осуществляеться примерно так: Иван Иванов, Иванов Иван, Иван 1985, Иванов пр.Ленина и т.п.
  Если использовать LIKE, то надо все поля индексировать, тоже дорого.
  Может можно придумать что?
Записан
Admin
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 1988



Просмотр профиля
« Ответ #3 : Февраль 12, 2006, 11:49 »

Я могу ошибатся но Like ищет кажется только по полю!

Можно сделать так:
Форма с галочками. Типа:
Фамилия : Иванов
Имя:
Отчество: Иванович
Год:

И не давать пользователю вводить строку типа Иван 1985.
Тогда поиск как у тебя делается легко!
Записан
danius
Гость
« Ответ #4 : Февраль 12, 2006, 14:14 »

IMHO галочки в принципе не нужны, просто пустые поля не искать.
   :idea: В принципе можно все параметры для поиска (фио, г.р., адрес и т.п.) собрать в одну таблицу (3) и используя связь многие-ко-многим (с использованием промежуточной таблицы (2)) на первоначальную таблицу(1). Тогда действуем так: ищем в (3) затем через (2) находим кучу записей в (1) и уже из них выбираем дальше :shock:.
  Только нам оно надо такой геморрой? Уж лучше с формой, хотя пользователю было бы удобнее, в программе толко таблица и поле ввода.
Записан
Admin
Administrator
Джедай : наставник для всех
*****
Offline Offline

Сообщений: 1988



Просмотр профиля
« Ответ #5 : Февраль 13, 2006, 12:21 »

Я тебе примерно тоже вверху написал! про промежуточную таблицу
Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.057 секунд. Запросов: 23.