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

Привет всем знатокам! У меня есть таблица, в ней есть

JSONB колонка values, в которой записан JSON вида:
[{value: 0, timestamp: '2020-11-11T00:00:00-06:00'}, {value: 0, timestamp: '2020-11-11T01:00:00-06:00'}, {value: 0, timestamp: '2020-11-11T02:00:00-06:00'}, ....... {value: 0, timestamp: '2020-11-11T23:00:00-06:00'}].

На входе у меня будет start_date, end_date.

Я хочу сделать запрос SELECT, но такой хитрый, чтобы в результате values были между start_date и end_date. Типа обрезать JSON и вернуть мне его) Это как-то можно сделать?:)

Накидал простой пример: https://dbfiddle.uk/?rdbms=postgres_11&fiddle=e646724f207bc7a55e7c91c6080fb273

Спасибо)

1 ответов

8 просмотров

Тут всего два удара бубном - развернуть JSON, отфильтровать, и завернуть обратно: SELECT json_agg(row_to_json(data)) FROM jsonb_to_recordset('[{"value": 0, "ts": "2020-11-11T00:00:00-06:00"}, {"value": 1, "ts": "2020-11-11T01:00:00-06:00"}, {"value": 2, "ts": "2020-11-11T02:00:00-06:00"},{"value": 23, "ts": "2020-11-11T23:00:00-06:00"}]') AS data(value integer, ts timestamp with time zone) WHERE data.ts BETWEEN '2020-11-11T00:10:00-06:00' AND '2020-11-11T02:10:00-06:00';

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

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

Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
48
Всем привет! Скажите, никто не пытался уменьшить размер процесса ssl, которые ассоциируется с открытым соединением (не помню точное название этого процесса, но там была какая-...
Алексей
20
а проверьте, собирается ли у кого сейчас транк лазаря через делюкс? у меня вот: fpcupdeluxe: info: Lazarus Native Installer (BuildModuleCustom: UserIDE): LazBuild: building Us...
Iluha Companets
20
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Мне тут приспичило встроить в программу форматировние текста SQL, расставить переносы строк и отступы так, чтобы лучше читалось. Я что-то свое изобразил, оно после ключевых сл...
Sergey Bodrov
11
добрый день. возможно ли изменить цвет окон лазаруса? Как?
Budemposmotret
35
Господа, а кто-нибудь сталкивался с размещением на TTabControl/TTabSheet множества контролов (> 100) с последующими External: Access violation? Вот буквально на ровном месте. ...
Dmitry
29
А какие существуют способы обработки ошибок выделения памяти в ядре? Т.е., допустим, есть функция, которая возвращает адрес свободной страницы в физической памяти и диапазон в...
disba1ancer
51
Добрый день. Опять снова хочу обратиться к вам за помощью. После создания проэкта stack new, lazy.nvim + nvim-lspconfig/haskell-tools + hlint, ormolu из mason + hls из ghcup ...
Nannk
8
Does anyone have some zeroday's left?
Wito!d ♥️🩷
44
Карта сайта