Зарегистрируйтесь для доступа к 15+ бесплатным курсам по программированию с тренажером

Условная агрегация CASE Продвинутые SQL-запросы

Условная агрегация – выполнение агрегирующей функции при определенных условиях (на определенных данных).

Условная агрегация

Оператор CASE

Оператор CASE служит для обработки и выполнения определенных условий

CASE [ expression]
    WHEN condition_1 THEN result_1
    WHEN condition_2 THEN result_2
    ...
    WHEN condition_n THEN result_n
    ELSE result
END

Принцип работы оператора CASE заключается в условном выполнении операций на основе заданных условий. Он позволяет проверять значение выражения и выполнять различные действия в зависимости от соответствия условиям.

Основные операторы, используемые в операторе CASE, включают:

  • WHEN: определяет условие, которое должно быть выполнено.

  • THEN: указывает действие, которое будет выполнено, если условие в операторе WHEN истинно.

  • ELSE: опциональный оператор, который указывает действие, которое будет выполнено, если ни одно из условий в операторах WHEN не истинно.

  • END: обозначает конец оператора CASE.

eyJpZCI6IjgzMDhkNDdiY2ExZDdlYzBiNTg5MzAzZDIxNTVkODg4LnBuZyIsInN0b3JhZ2UiOiJjYWNoZSJ9?signature=a89933a6a9b5f8402ff60fe016f1c1fc1fd66814f2ed7eb44e04f9dacddb0277

Особенности использования CASE

  • Условия WHENTHEN выполняются в порядке приоритета написания. После первого совпадения остальные ветки уже не выполняются.

  • Если условие не примет TRUE, то оператор CASE вернет значение предложения ELSE.

  • Если предложение ELSE опущено и условие не примет TRUE, то оператор CASE вернет NULL.

  • Оператор CASE может иметь до 255 сравнений. Каждое предложение WHEN …​ THEN рассматривает 2 сравнения.

Применение CASE

Применение CASE

Аватары экспертов Хекслета

Остались вопросы? Задайте их в разделе «Обсуждение»

Вам ответят команда поддержки Хекслета или другие студенты

Об обучении на Хекслете

Для полного доступа к курсу нужен базовый план

Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.

Получить доступ
1000
упражнений
2000+
часов теории
3200
тестов

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно

  • 130 курсов, 2000+ часов теории
  • 1000 практических заданий в браузере
  • 360 000 студентов
Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

Наши выпускники работают в компаниях:

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff
Рекомендуемые программы
профессия
от 5 025 ₽ в месяц
новый
Сбор, анализ и интерпретация данных
9 месяцев
с нуля
Старт 2 мая

Используйте Хекслет по-максимуму!

  • Задавайте вопросы по уроку
  • Проверяйте знания в квизах
  • Проходите практику прямо в браузере
  • Отслеживайте свой прогресс

Зарегистрируйтесь или войдите в свой аккаунт

Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»