~* '(foo|bar)';
Какой синтаксис будет у операнда AND ? 🤔
Советую использовать несколько операторов и AND . То есть придумать — можно, что-нибудь вроде SELECT 'ABCD' ~* '(?=.*b).*a'; но... Шансов на оптимизацыю этого — меньшэ, чем с несколькими операторами.
при перестановке слов оно перестанет работать) Задача - найти строку, которая содержит все слова - типа Ночь, улица, фонарь, аптека ... хотелось бы обойтись без доп колонки для хранения триграмм и только индекс... Бд - справочная.
Что значит "перестанет"? Вы пробовали совет @tzirechnoy ? Вот ещё вариант: WHERE t ~* 'foo.*bar|bar.*foo'
Да - пробовал. .* означает любое кол во символов. и оканчивается на - .*a учитывая, что слов может быть до 5-ти, последний вариант разрастается до неприемлемого. Есть решение в виде to_tsvector @@ to_tsquery('ноч & улица & фонарь ') + immutable функцию в индекс... ищу решение попроще... нет, так нет)
Нет. Можэте попробовать.
> Да - пробовал. И что? В смысле — в чём проблема-то, конкретно? Можете показать пример, в котором что-то не так? > учитывая, что слов может быть до 5-ти, последний вариант разрастается до неприемлемого. Прямо уж вот до неприемлемого (5! = 120, всего-то). ;) Но разрастается, это да (и работает он только для непересекающихся подстрок).
Сорри! да - так вроде работает: ~* '(?=.*ярослав)(?=.*центр)(?=.*фбуз)' Спасибо! - пошел изучать регуляки ...
Но я почти уверен, что оно работает не быстрее, чем field ~* 'ярослав' AND field ~* 'центр' AND field ~* 'фбуз'
Возможно - перебираю все варианты) Пока вижу что индекс с USING gin ((to_tsvector('russian' в 2 раза меньше чем USING gin ((field ) gin_trgm_ops) ... Еще раз спасибо за наводку!
Обсуждают сегодня