powered by simpleCommunicator - 2.0.60     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Tsearch2 в PgSql-8.3
4 сообщений из 4, страница 1 из 1
Tsearch2 в PgSql-8.3
    #35469993
shuler239
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Добрый день.
Пытаюсь осваивать полнотекстовый поиск в pgsql.
Столкнулся с проблемой, решение которой должно быть на поверхности.

Задача: сделать конфигурацию, при которой будут работать индексация слов разных языков, используя ispell.

Реализация:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
CREATE TEXT SEARCH DICTIONARY english_ispell (
  TEMPLATE = ispell,
  DictFile = english,
  AffFile = english,
  StopWords = english
);

CREATE TEXT SEARCH DICTIONARY russian_ispell (
  TEMPLATE = ispell,
  DictFile = russian,
  AffFile = russian,
  StopWords = russian
);

CREATE TEXT SEARCH CONFIGURATION public.mydict_ru (PARSER = default);

ALTER TEXT SEARCH CONFIGURATION mydict_ru ADD MAPPING 
 FOR word, hword_part, hword
 WITH russian_ispell, english_ispell;

В итоге индексируются только русские слова.
Помогите решить проблему.
...
Рейтинг: 0 / 0
Tsearch2 в PgSql-8.3
    #35470004
shuler239
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Прошу прощения, вопрос исчерпан.
Надо лишь уметь пользоваться ts_debug.
...
Рейтинг: 0 / 0
Tsearch2 в PgSql-8.3
    #35470401
tadmin
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Если вы нашли свою ошибку, то было бы правильно объяснить, в чем она была (ts_debug, конфиг).
Вы понимаете, что такими сообщениями без ответа вы просто засоряете результаты поиска?
...
Рейтинг: 0 / 0
Tsearch2 в PgSql-8.3
    #35470902
shuler239
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Да, простите.
Решение было в том, что в моем случае английскому слову соответствовал token "asciiword".

Таким образом, надо конфиг должен быть таким:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
CREATE TEXT SEARCH DICTIONARY english_ispell (
  TEMPLATE = ispell,
  DictFile = english,
  AffFile = english,
  StopWords = english
);

CREATE TEXT SEARCH DICTIONARY russian_ispell (
  TEMPLATE = ispell,
  DictFile = russian,
  AffFile = russian,
  StopWords = russian
);

CREATE TEXT SEARCH CONFIGURATION public.mydict_ru (PARSER = default);

ALTER TEXT SEARCH CONFIGURATION mydict_ru ADD MAPPING 
 FOR word, hword_part, hword
 WITH russian_ispell;

ALTER TEXT SEARCH CONFIGURATION mydict_ru ADD MAPPING 
 FOR asciiword
 WITH english_ispell;
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / Tsearch2 в PgSql-8.3
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]