Russian Qt Forum
Ноябрь 22, 2024, 22:41
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Программирование
>
Базы данных
>
Контекстный поиск
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Контекстный поиск (Прочитано 7907 раз)
danius
Гость
Контекстный поиск
«
:
Февраль 10, 2006, 07:42 »
Кто нибудь сталкивался с такой задачей: реляционная база данных, несколько полей (пусть текстовых). Необходимо выполнить контекстный поиск
по всем полям
сразу.
Первое, что приходит в голову объединить все поля в одно и выполнять поиск в нём, но imho большие затраты, т.к. база довольно большая (~500 ты. записей, ~10 полей).
Если кто-то уже решал такую проблему подскажите. Спасибо.
Записан
Admin
Administrator
Джедай : наставник для всех
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
Сообщений: 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
Сообщений: 1988
Контекстный поиск
«
Ответ #5 :
Февраль 13, 2006, 12:21 »
Я тебе примерно тоже вверху написал! про промежуточную таблицу
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...