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

Подскажите, как сделать такой запрос? select * from templates where (content->'property_ids')

@> any(array[0, 1609]);

property_ids это массив bigint
Т.е. надо найти все темплейты, где в property_ids находится любой из переданных айдишников.
Уже 4й час мучаюсь

3 ответов

13 просмотров

Хмм... а я вот не могу сходу придумать ничего красивого. Тут у нас есть специалисты по jsonpath — может, они подскажут? А если как-то так? SELECT t.*, ja.v_arr FROM templates AS t CROSS JOIN LATERAL ( SELECT array_agg(a.v) AS v_arr FROM jsonb_array_elements_text(t.content->'property_ids') AS a(v) ) AS ja WHERE ja.v_arr && ($1)::text[]; Кстати, @> — это же не "любой из", а "все из переданных" (в общем, проверьте, что именно нужно).

Dmitry- Автор вопроса
Yaroslav Schekin
Хмм... а я вот не могу сходу придумать ничего крас...

Сделал в итоге через вложенный селект, спасибо

Dmitry
Сделал в итоге через вложенный селект, спасибо

Можно примерно так сделать без подзапроса с помощью jsonpath: select * from templates where jsonb_path_query( content, '$.property_ids[*] == $ids[*]', jsonb_build_object('ids', to_jsonb(array[0, 1609])) );

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта