172 похожих чатов

Привет всем, подскажите пожалуйста: я использую встроенный в постгрес FTS.

Для каждого поискового запроса я создаю строку tsquery запроса. Например, для строки «крокодил Гена», у меня формируется запрос «крокодил:* & Гена:*» и всё как бы хорошо. Но проблема в том, как осуществлять поиск по строкам «гена & друзья», если у меня амперсанд пересекается с ним же в самом запросе, получая: «Гена:* & &:* & друзья:*». Как осуществлять поиск в таком случае? Удалять все спец. символы из искомой строки? Но что если они важны в контексте запроса?

2 ответов

8 просмотров

экранировать?

Во-первых — ну да, или писать свой парзер (на сях, плюс он только один встроенный — и особо примеров переписывания нет) — или преобразовывать строку https://www.postgresql.org/docs/16/textsearch-parsers.html Во-вторых — дажэ если преобразовать & в and — то сам and выкинется по списку "stopwords". https://www.postgresql.org/docs/16/textsearch-dictionaries.html#TEXTSEARCH-STOPWORDS Тут ужэ или писать свой словарь (впрочем, словарей написано реально много, можэт можно какой готовый взять) или опять преобразовывать строку... Хотя, учитывая, что в позицыях слово and учитывается — можно тут в to_tsquery это пропустить, просто что-то вроде ген <2> друз В общем, попробуйте сами to_tsvector(...) , можэт и найдёте что подходящее.

Похожие вопросы

Обсуждают сегодня

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
Всем доброго дня! Подскажите может кто использовал связку Pagebuilder + Clientsetting. Сами параметры с типом pagebuilder в модуле Clientsetting работают нормально, можно такж...
Александр Добриков
12
А почему в си некоторые вещи работают с двойными кавычками некоторые с одинарными? Нельзя было все сделать с одними или чтоб работало с разными? например чтоб выводить строки ...
.
15
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! procedure TForm1.FormCreate(Sender: TObject); type TStartEnd = record S: Byte; E: Byte; end; var a, b: TStartEnd; begin {1} a.S := 1; {2} a.E := 2; ...
Руслан Михайлович
10
Всем привет!) я тут новенький и пытаюсь освоить evolution методом тыка. У меня при переходе между папками файлов выскакивают вот такие уведомления Можете подсказать как их от...
Диман Samoed
10
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Карта сайта