Слияние перекрывающихся периодов

Сложная gaps_islands Stripe-style

Условие задачи

Таблица subscriptions содержит id, user_id, start_date, end_date. Один user_id может иметь несколько перекрывающихся подписок. Найдите для каждого юзера ОБЪЕДИНЁННЫЕ периоды (если два периода накладываются или соприкасаются — сливаем). Выведите user_id, merged_start, merged_end. Отсортируйте по user_id, merged_start.

Схема данных

CREATE TABLE subscriptions (id INTEGER PRIMARY KEY, user_id INTEGER, start_date TEXT, end_date TEXT);

Темы

CTE OVER MAX PARTITION BY gaps_islands

Подсказки

Решить в интерактивной SQL-песочнице → ← Все SQL-задачи