8 октября 2024

eur = 105.31 0.56 (0.54 %)

btc = 63 100.00$ - 507.01 (-0.80 %)

eth = 2 449.82$ -34.33 (-1.38 %)

ton = 5.23$ -0.05 (-0.93 %)

usd = 96.06 1.19 (1.26 %)

eur = 105.31 0.56 (0.54 %)

btc = 63 100.00$ - 507.01 (-0.80 %)

Форум

Задания по 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».

Сейчас читают

Картина дня

7 октября, 2024
7 октября, 20246 минут на чтение
Фото Артём Багдасаров
Артём Багдасаров
6 минут на чтение
[ Новости ]
[ Статьи ]
Личный опыт работы
Блоги 274