Таблица events(user_id, event_at). Нужно для каждого юзера найти первое и последнее событие. Самое эффективное на 200M строк?
SQLmediummiddle
Варианты ответа
SELECT user_id, MIN(event_at), MAX(event_at) FROM events GROUP BY user_id — single scan, агрегаты считаются за один проход, без сортировки
SELECT user_id, FIRST_VALUE(event_at) OVER w, LAST_VALUE(event_at) OVER w FROM events WINDOW w AS (PARTITION BY user_id ORDER BY event_at)
SELECT user_id, e1.event_at, e2.event_at FROM events e1 LEFT JOIN events e2 USING (user_id) WHERE e1.event_at < e2.event_at
WITH ordered AS (SELECT *, ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY event_at) AS rn FROM events) SELECT user_id, MIN(...), MAX(...) FROM ordered GROUP BY 1
Разбор ответа
Подробный разбор с объяснением «почему правильный ответ верный» и почему остальные неверны — после регистрации.
2475 вопросов с разбором, quiz-режим с проверкой, AI-собес и подготовка к интервью аналитика.