-
Я хочу часто проводить поиск по полю varchar(2500) на вхождению подстроки в любом месте, соответственно нужно максимально ускорить этот поиск. Проиндексировать поле MS SQL не дал, мол максимум 900 символов. Что можно предпринять? Как лучше искать, Locate или SQL select?
-
> [0] ocean (15.04.09 12:49)
> Как лучше искать, Locate или SQL select?
Сделай и сравни. Делов то на 10 минут.
-
>ocean (15.04.09 12:49)
в случае с произвольной подстрокой индекс бы ничего не дал в плане производительности)
-
> [0] ocean (15.04.09 12:49)
А что в этом поле? Как много азписей в таблице? Как часто надо искать?
Возможно неплохим решением будет создать подчиненную таблицу ключевых слов текста для поиска.
-
В поле плоский текст. Не знаю как оценить частоту, допустим раз в неск. секунд. С ключевыми словами интересная мысль, но тогда надо придумать, как их вычленять?
-
Можно попробовать FullTextSearch подключить. Но не факт, что это офигенную скорость даст.
-
> Возможно неплохим решением будет создать подчиненную таблицу ключевых слов текста для поиска.
в mssql это уже есть, называется полнотекстовый поиск. нужно просто включить, и пользоваться.
-
> в mssql это уже есть, называется полнотекстовый поиск. нужно
> просто включить, и пользоваться.
Тяжелый он очень в MSSQL. К сожалению. И я не нашёл, как его настраивать тонко можно (игрался с MSSQL 2000).
-
Прочитал про полнотекстовый поиск, выглядит как то что нужно, но:
"к сожалению в SQL Server изначально не реализована возможность полнотекстового поиска на русском, украинском языках." Это все Кондолиза устроила. Не понял, как включить таблицу в полнотекстовый поиск не из среды MSSQL, а программно. Сейчас погоняю.
-
> ocean (15.04.2009 12:49:00) [0]
К поиску тут относится только Locate
-
Индексы или полнотекстовый поиск для
подстроки, придется строить по всем вариантам поиска!
вариант
ариант
риант
иант
ант
и это только по одному слову, а не по совокупности слов строки.
-
> К поиску тут относится только Locate
Но и его нельзя применить для поиска подстроки.
Надо отказаться от поиска и заменить выборкой с отбором по подстроке. Медленно, но что делать.
-
ocean (15.04.09 14:40) [8]
MSSQL 2005 юзай.
-
> к сожалению в SQL Server изначально не реализована возможность
> полнотекстового поиска на русском
реализована (начиная с 2005 точно), но не включена по умолчанию
-
А как в оракле такую фичу подключить ?
Я задрался уже запросы распараллеливать ради такой ерунды.
И писать разбивку по словам для нашей базы - очень неоптимально - места уже впритык на сервере.
-
> такую фичу подключить ?
> места уже впритык на сервере.
а как ты думаешь эта фича реализована? где она будет хранить разбивку/индексы?
-
>ANB (16.04.09 12:11) [14]
>А как в оракле такую фичу подключить ?
interMedia
-
>Кщд (16.04.09 13:08) [16]
если информация структурирована, то нам, например, отлично помог ctx-индекс для поиска по достаточно большому хранилищу XML-документов
-
> если информация структурирована
Если бы. Это имя клиента, вбитое как попало.