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

Камрадам - доброго! Что то заклинило... https://postgrespro.ru/docs/postgresql/15/pgtrgm SELECT * FROM test_trgm WHERE t

~* '(foo|bar)';

Какой синтаксис будет у операнда AND ? 🤔

9 ответов

14 просмотров

Советую использовать несколько операторов и AND . То есть придумать — можно, что-нибудь вроде SELECT 'ABCD' ~* '(?=.*b).*a'; но... Шансов на оптимизацыю этого — меньшэ, чем с несколькими операторами.

Rinat-Karimov Автор вопроса
Ilya Anfimov
Советую использовать несколько операторов и AND . ...

при перестановке слов оно перестанет работать) Задача - найти строку, которая содержит все слова - типа Ночь, улица, фонарь, аптека ... хотелось бы обойтись без доп колонки для хранения триграмм и только индекс... Бд - справочная.

Rinat Karimov
при перестановке слов оно перестанет работать) Зад...

Что значит "перестанет"? Вы пробовали совет @tzirechnoy ? Вот ещё вариант: WHERE t ~* 'foo.*bar|bar.*foo'

Rinat-Karimov Автор вопроса
Yaroslav Schekin
Что значит "перестанет"? Вы пробовали совет @tzire...

Да - пробовал. .* означает любое кол во символов. и оканчивается на - .*a учитывая, что слов может быть до 5-ти, последний вариант разрастается до неприемлемого. Есть решение в виде to_tsvector @@ to_tsquery('ноч & улица & фонарь ') + immutable функцию в индекс... ищу решение попроще... нет, так нет)

Rinat Karimov
Да - пробовал. .* означает любое кол во символов. ...

> Да - пробовал. И что? В смысле — в чём проблема-то, конкретно? Можете показать пример, в котором что-то не так? > учитывая, что слов может быть до 5-ти, последний вариант разрастается до неприемлемого. Прямо уж вот до неприемлемого (5! = 120, всего-то). ;) Но разрастается, это да (и работает он только для непересекающихся подстрок).

Rinat-Karimov Автор вопроса
Ilya Anfimov
Нет. Можэте попробовать.

Сорри! да - так вроде работает: ~* '(?=.*ярослав)(?=.*центр)(?=.*фбуз)' Спасибо! - пошел изучать регуляки ...

Rinat Karimov
Сорри! да - так вроде работает: ~* '(?=.*ярослав)(...

Но я почти уверен, что оно работает не быстрее, чем field ~* 'ярослав' AND field ~* 'центр' AND field ~* 'фбуз'

Rinat-Karimov Автор вопроса
Ilya Anfimov
Но я почти уверен, что оно работает не быстрее, че...

Возможно - перебираю все варианты) Пока вижу что индекс с USING gin ((to_tsvector('russian' в 2 раза меньше чем USING gin ((field ) gin_trgm_ops) ... Еще раз спасибо за наводку!

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

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

Типа вызывать GetParent и проверять на соответствие GetModuleHandle?
The Bird of Hermes
67
Do any of you guys have interesting projects one could join? I'm a Middle Full-Stack developer (JS/TS, React & Node)
Lev Shapiro
40
$res = json_decode($наша строка из респонса); $res1 = array_map(fn($o) => $o->name, $res->breadcrumbs[0]->entities); Как такое будет на Хаскеле?.. В начале весь джейсон, в ко...
Хаскель Моисеевич Гопник
27
В чем сила брат, в NASM или FASM?
Isaac Kleiner
18
Вопрос по диагностике ошибок (я знаю в чем, в данном конкретном примере, я знаю, как исправить, пример модельный, понятно, что в реальности бывает намного запутаннее). module...
ⰄⰎⰋⰐⰐⰑⰛⰤⰧⰧⰩⰄ ⰊⰑⰁⰓⰡⰛⰦⰕⰫ
11
А чем вам питонисты не угодили?😂
.
79
Есть какой-нибудь для Delphi/FPC T*Compression(Decompression)Stream на базе LZ4/Zstd/любой другой быстрый(и хорошо сжимающий) алгоритм А ещё лучше в pure pascal А ещё лучше од...
notme
52
Хтось використовував Vapor на Windows?
Jaroshevskii
15
Какое виндузовое сообщение приходит TTabSheet, что риэлайняться контролы на нем, даже у которых парент другой? Ситуация: открываю форму - кнопок нет, перелистываю на другой т...
Катерина Свиридова
7
Тут кста кто-нибудь NeoVim использует?
Simple Sorcerer
13
Карта сайта