Второй заказ клиента без задвоения от позиций

Сложная Оконные функции Райффайзен

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

Есть 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-задачи