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

Всем привет вопрос, умеет ли postgresql постпроцессинг like? суть такая - код

хранит в БД англоязычную строку string/enum, а внутри имеет русскоязычные наименования.

Возможно ли провернуть такой трюк с поиском по результату case через like?

select
s.hostname,
case
when s.status = 'new' then 'Новый'
when s.status = 'exists' then 'Существует'
when s.status = 'changing' then 'Изменение'
when s.status = 'deleting' then 'Удаление'
when s.status in ('new_deleted', 'deleted') then 'Удален'
else s.status
end as status_text
from servers s
where status_text like '%ение%'

Ожидаю увидеть в качестве результата все записи со статусами Изменение и Удаление

8 ответов

7 просмотров

Используйте вложенный запрос или CTE. И при чём тут "постпроцессинг"? Это же просто логическая последовательность выполнения запросов, в "будущее" PostgreSQL не заглядывает. ;)

Daniil Zobov
что такое CTE?

WITH cte_name AS (SELECT ...) SELECT .. FROM cte_name ...

а почему просто по like '%ing%' не это, не того?)

Daniil-Zobov Автор вопроса
Igor Komarov
а почему просто по like '%ing%' не это, не того?)

конечный юзверь видит в морде Новый, Существует, итп)

Daniil-Zobov Автор вопроса
Yaroslav Schekin
WITH cte_name AS (SELECT ...) SELECT .. FROM cte_...

with status_enum (status, name) as ( values ('new', 'Новый'), ('exists', 'Существует'), ('changing', 'Изменение'), ('deleting', 'Удаление'), ('new_deleted', 'Удален'), ('deleted', 'Удален') ) select s.hostname, se.name from servers s join status_enum se on s.status = se.status where se.name like '%ение%'

Daniil Zobov
конечный юзверь видит в морде Новый, Существует, и...

Так выберите подходящие статусы на стороне приложения. Вы же где-то храните исходные данные для when s.status = 'exists' then 'Существует', вот и фильтруйте этот список соответствий, чтобы получить status IN ('exists', 'deleting'). Оно работать на порядки быстрее будет.

Daniil-Zobov Автор вопроса
Евгений Смирнов
Так выберите подходящие статусы на стороне приложе...

я проблематику, видимо, не до конца объяснил) у меня самописный поисковой движок, который ищет по всем колонкам одновременно. Юзать индексы sqlite либо elastic не представляется возможным из-за возможного лага в обновлении, плюс поиск по записи в себе содержит еще кучу данных из соседних записей из таблиц, связанных с искомой - тут включается еще триггерное обновление индекса при изменении зависимой сущности Сейчас человек может написать поисковую строчку, которую код раскидает на токены-слова-условия, и айлайком пройдется по полям в зависимости от их типа. Вот как раз enum’а не хватало, with cte прекрасно справился со своей задачей без лишнего усложнения кода P.S. для поиска автоматически генерируются километровые SQL запросы и PostgreSQL их прекрасно жрет и очень быстро ищет

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

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

подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Коллеги, здравствуйте! А можно узнать ваше мнение относительно Wolfram Mathematica vs Julia? Просто у меня стоит выбор между тем, чтобы продолжить преподавать Wolfram Mathemat...
Илья Гаража
10
Обновленный chat тестили уже господа? Готовимся на заводы ? Простой проект на ларавель собирает за 1 ответ..
Jacov Borisov
14
А если без шуток, на чем десктоп сейчас пишут кроссплатформенный (ну чтобы с минимальным допиливанием под каждую платформу) и чтобы хорошая производительность софта была. Толь...
🐈
9
кому не сложно распишите пожалуйста для какой цели тут вот эти скобки и в них пихается указатель?
Михаил Helper
15
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
На одной бирже предложили обновить modx evo 1.0.1 Как думаете, стоит браться?
Artem
9
Такс, блин, таки кто-то знает, каким образом работают макросы stdin/stdout/stderr? Я влез в stdio.h, там определения нет, отладил через асмокод - вызывается функция со странны...
The Bird of Hermes
18
словил ушиб всей бабки Uncaught Error: Class "EvolutionCMS\Main\MainServiceProvider" not found in и ни composer update, ни composer dump-autoload не помогает что ещё сделать...
Oleg Nosov
7
Карта сайта