Таблица 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