15 декабря 2024

eur = 109.01 -1.47 (-1.33 %)

btc = 102 203.00$ 824.09 (0.81 %)

eth = 3 865.98$ -27.37 (-0.70 %)

ton = 6.23$ -0.07 (-1.05 %)

usd = 103.43 -0.52 (-0.50 %)

eur = 109.01 -1.47 (-1.33 %)

btc = 102 203.00$ 824.09 (0.81 %)

Форум

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

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

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».

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

Важные новости коротко — от GigaChat Max 
1-bg-изображение-0
img-content-1-изображение-0

GigaChat Max: коротко о главном

Как изменился Код Дурова вместе с GigaChat Max?

Узнай о всех возможностях в FAQ-статье 
7e562024-15e4-4952-8368-7460291312b8-изображение-0

GigaChat Max: коротко о главном

Meta* выступила против преобразования OpenAI в коммерческую структуру

Полная версия 
9c042993-c5ec-4563-97ea-f0396a1eff41-изображение-0

GigaChat Max: коротко о главном

В NASA считают, что освоение Марса невозможно без привлечения частного сектора

Полная версия 

Реализовано через GigaChat Max 

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