7-дневный Retention когорты

Middle SQL Gaming

Условие задания

**Данные:** Две таблицы мобильной игры — `user_activity` (активность) и `users` (регистрации):

[см. код в задании]

**Задание:**
1. Рассчитайте 7-дневный Retention (Day 7) для каждой недельной когорты регистрации
2. Когорта определяется по неделе регистрации (`DATE_TRUNC('week', registered_at)`)
3. Day 7 Retention — доля пользователей когорты, которые вернулись ровно на 7-й день после регистрации

Пример данных

Структура для ориентира — реальные значения из эталонного решения.

CREATE TABLE user_activity (
    user_id INT NOT NULL,
    activity_date DATE NOT NULL,
    session_count INT NOT NULL DEFAULT 1
);

CREATE TABLE users (
    id SERIAL PRIMARY KEY,
    registered_at DATE NOT NULL
);

Темы

CTE подзапросы Retention когорты JOIN

Подсказки

Все тестовые задания →

Частые вопросы

Какой уровень знаний нужен для задачи "7-дневный Retention когорты"?

Это задание для уровня Middle. Для middle-аналитиков с опытом 1-3 года, требует уверенного владения темой и понимания edge cases.

На каких собеседованиях встречается такая задача?

Подобные задания в категории «SQL» регулярно дают на собеседованиях аналитика данных в Яндекс, Сбер, Ozon, Авито, Тинькофф, Wildberries, T-Bank, X5, ВТБ и других крупных IT-компаниях. Тематика: CTE, подзапросы, Retention, когорты, JOIN.

Сколько времени даётся на решение?

На реальном собеседовании на подобную задачу отводится 15-30 минут — оцениваются подход, корректность, обработка edge cases. Для тренировки рекомендуем сначала решить самостоятельно, потом сверить с эталонным решением и подсказками.

Где ещё потренироваться по теме «SQL»?

На zasqlpython.ru есть 425 SQL задач в песочнице с автопроверкой кода, конспекты SQL для аналитика, AI мок-собеседование с разбором ваших ответов.

← Все задания