Есть orders (заказы) и order_items (позиции заказа, несколько строк на заказ). Для каждого клиента, у которого минимум 2 заказа, найди его ВТОРОЙ по времени заказ: его сумму (qty*price по всем позициям, без задвоения от джойна) и сколько дней прошло от первого заказа клиента. Columns: customer_id, second_order_id, second_order_date, second_order_amount, days_since_first. Сортируй по customer_id.
CREATE TABLE orders (
order_id INTEGER PRIMARY KEY,
customer_id INTEGER NOT NULL,
order_date TEXT NOT NULL
);
CREATE TABLE order_items (
item_id INTEGER PRIMARY KEY,
order_id INTEGER NOT NULL,
qty INTEGER NOT NULL,
price REAL NOT NULL
);
window row_number first_value fan-out cte joins
Задача «Второй заказ клиента без задвоения от позиций» учит применять оконные функции: нарастающие итоги, ранжирование (ROW_NUMBER/RANK) и сравнение со соседними строками (LAG/LEAD). Такие задачи встречаются на собеседованиях в Райффайзен и других IT-компаниях. Уровень сложный — задача проверяет глубину и умение собрать запрос из нескольких приёмов.
Сначала разберись со схемой данных и пойми, какой результат нужен на выходе. Определи, какие таблицы и поля задействованы, и собирай запрос пошагово: фильтрация → соединение или группировка → итоговый отбор и сортировка. Проверь результат на крайних случаях — NULL, дубликаты, пустые группы. Свой запрос сразу прогоняешь автопроверкой в интерактивной SQL-песочнице на реальной базе (SQLite и PostgreSQL 16 прямо в браузере).
Разбор темы с примерами — в гайде «Оконные функции в SQL». Хочешь системно с нуля — пройди бесплатный курс «SQL с нуля».
Решить в интерактивной SQL-песочнице → ← Все SQL-задачи