21 ноября 2024

eur = 105.81 0.08 (0.07 %)

btc = 96 901.00$ 3 658.30 (3.92 %)

eth = 3 139.03$ 13.36 (0.43 %)

ton = 5.55$ 0.09 (1.56 %)

usd = 100.22 0.18 (0.18 %)

eur = 105.81 0.08 (0.07 %)

btc = 96 901.00$ 3 658.30 (3.92 %)

Форум

Задания по SQL с реальных собеседований. Сможете их решить?

3 минуты на чтение
Задания по SQL с реальных собеседований. Сможете их решить?

Читать первым в Telegram-канале «Код Дурова»

SQL — один из самых востребованных навыков в IT.

Давайте разберем несколько задач, которые предлагают решить на собеседованиях специалистам разных уровней.

Вводные к задачам

Мы будем решать задачи, опираясь на эти таблицы:

Задача № 1. Для уровня Junior

Задание. Вывести название и цену каждого анализа, которые продавались 5 февраля 2020 года и в течение всей следующей недели.

Примечание. С помощью этой задачи проверяют, знает ли человек SELECT-запросы и есть ли у него навык работы с датой и временем. На собеседовании смотрят на то, правильно решена задача или нет, а специфика диалекта редко имеет значение. Если вам привычнее PostgreSQL, спокойно работайте там.

Ответ к задаче № 1

Задача № 2. Для уровня Middle

Задание. Нарастающим итогом рассчитать, как каждый месяц каждого года увеличивалось количество проданных тестов с разбивкой по группе.

Примечание. С помощью этой задачи проверяют, понимает ли человек на базовом уровне оконные функции, джоины и группировки. Когда первая версия запроса будет написана, сделайте его оптимизацию. Так, в этом примере у нас CTE — обобщенные табличные выражения.

Ответ к задаче № 2

Задача № 3. Для уровня Senior

В этой задаче вы будете работать всего с одной таблицей. Запрос здесь не сложный, но чтобы его написать, нужно уметь «мыслить на SQL».

Вот таблица балансов клиентов:

ClientBalance(client_id, client_name, client_balance_date, client_balance_value)

  • client_id — идентификатор клиента;
  • client_name — ФИО клиента;
  • client_balance_date — дата баланса клиента;
  • client_balance_value — значение баланса клиента.

Задание. Здесь есть полные дубли. Попробуйте от них избавиться, не создавая новую таблицу.

Ответ к задаче № 3

Вопрос № 1. Для уровня Junior

На собеседованиях любят задавать «хитрые» вопросы, чаще Junior-специалистам, но остальным тоже перепадает. Вот один из таких вопросов.

Вопрос. Как оператор GROUP BY обрабатывает поля с NULL?Ответ. С учетом того, что NULL в SQL — это отсутствие значения, при группировке все значения NULL оказываются в одной группе. Возьмем вот такую таблицу:

Тогда запрос select sum(score) from table group by name даст:

Вопрос № 2. Для уровня Middle

Тут все не так хитро, как в вопросе № 1, но здесь требуется знать оконные функции и их тонкости. А это вполне себе требование для Middle.

Вопрос. Чем отличается функция RANK() от DENSE_RANK()?

Примечание. Задачи на основе подобного вопроса часто дают на собеседованиях. Скажем, пронумеровать строки с одинаковыми значениями без разрывов, с разрывами и т. д. Так что есть смысл на досуге потренироваться.

Ответ. Подобно функции ROW_NUMBER, оконные функции RANK и DENSE_RANK служат для нумерации строк. Но с ними все происходит отчасти по-другому: строки с одинаковыми значениями получают одинаковый ранг. При некоторых задачах это вполне оправданно. Когда два сотрудника получают одинаковую зарплату, нельзя разделить их на первого и второго, они одинаковые. Тогда вопрос: какой ранг должен быть у следующего сотрудника? Если у первых ранг 1, то у следующего сотрудника он будет 2 или 3?

Вместо заключения

Здесь только пять вероятных задач, с которыми вы можете столкнуться во время собеседования. Но таких задач сотни, и придется решать их пачками, чтобы разобраться в теории, как следует ее прочувствовать и «начать думать на SQL».

Сейчас читают
Карьера
Блоги 295
Т-Банк
Газпромбанк
X5 Tech
МТС
Сбер
билайн
Яндекс Практикум
Ozon Tech
Циан
Банк 131