Я пытаюсь создать временные интервалы разной длины, например. 0–5:00, 10:00–13:00, 18:00–20:00 ежедневно, примерно так:
+--------------------------+--------------------------+
|start |finish |
+--------------------------+--------------------------+
|2022-05-17 00:00:00.000000|2022-05-17 05:00:00.000000|
|2022-05-17 10:00:00.000000|2022-05-17 13:00:00.000000|
|2022-05-17 18:00:00.000000|2022-05-17 20:00:00.000000|
|2022-05-18 00:00:00.000000|2022-05-18 05:00:00.000000|
|2022-05-18 10:00:00.000000|2022-05-18 13:00:00.000000|
|2022-05-18 18:00:00.000000|2022-05-18 20:00:00.000000|
+--------------------------+--------------------------+
Это то, что у меня есть до сих пор, но оно не работает, потому что генерирует продукт двух массивов:
SELECT day + a AS start,
day + b AS finish
FROM GENERATE_SERIES('2022-05-17'::timestamp, '2022-05-18'::timestamp, '1 day'::interval) day,
UNNEST('{"0 hours", "10 hours", "18 hours"}'::interval[]) a,
UNNEST('{"5 hours", "13 hours", "20 hours"}'::interval[]) b;
Результат:
+--------------------------+--------------------------+
|start |finish |
+--------------------------+--------------------------+
|2022-05-17 00:00:00.000000|2022-05-17 05:00:00.000000|
|2022-05-17 00:00:00.000000|2022-05-17 13:00:00.000000|
|2022-05-17 00:00:00.000000|2022-05-17 20:00:00.000000|
|2022-05-17 10:00:00.000000|2022-05-17 05:00:00.000000|
|2022-05-17 10:00:00.000000|2022-05-17 13:00:00.000000|
|2022-05-17 10:00:00.000000|2022-05-17 20:00:00.000000|
|2022-05-17 18:00:00.000000|2022-05-17 05:00:00.000000|
|2022-05-17 18:00:00.000000|2022-05-17 13:00:00.000000|
|2022-05-17 18:00:00.000000|2022-05-17 20:00:00.000000|
|2022-05-18 00:00:00.000000|2022-05-18 05:00:00.000000|
|2022-05-18 00:00:00.000000|2022-05-18 13:00:00.000000|
|2022-05-18 00:00:00.000000|2022-05-18 20:00:00.000000|
|2022-05-18 10:00:00.000000|2022-05-18 05:00:00.000000|
|2022-05-18 10:00:00.000000|2022-05-18 13:00:00.000000|
|2022-05-18 10:00:00.000000|2022-05-18 20:00:00.000000|
|2022-05-18 18:00:00.000000|2022-05-18 05:00:00.000000|
|2022-05-18 18:00:00.000000|2022-05-18 13:00:00.000000|
|2022-05-18 18:00:00.000000|2022-05-18 20:00:00.000000|
+--------------------------+--------------------------+
🤔 А знаете ли вы, что...
PostgreSQL активно развивается и обновляется, включая в себя новые возможности и улучшения.
Вы должны разделить два массива на один выбор, чтобы сделать это параллельно (оба массива должны иметь одинаковое количество элементов)
SELECT day + c.a AS start,
day + c.b AS finish
FROM GENERATE_SERIES('2022-05-17'::timestamp, '2022-05-18'::timestamp, '1 day'::interval) day,
(
select
UNNEST('{"0 hours", "10 hours", "18 hours"}'::interval[]) a,
UNNEST('{"5 hours", "13 hours", "20 hours"}'::interval[]) b
) c;
На самом деле я придумал решение, которое работает, но оно немного уродливо, и, вероятно, есть лучший способ:
WITH days AS (SELECT GENERATE_SERIES('2022-05-17'::timestamp, '2022-05-18'::timestamp, '1 day'::interval) AS day)
SELECT day AS start,
day + INTERVAL '5 hours' AS finish
FROM days
UNION
SELECT day + INTERVAL '10 hours',
day + INTERVAL '12 hours'
FROM days
UNION
SELECT day + INTERVAL '20 hours',
day + INTERVAL '22 hours'
FROM days
ORDER BY start;