Sobes.tech
Назад к вопросам
Junior — Middle
63

Как последовательность выполнения операторов GROUP BY, HAVING и WHERE влияет на результат запроса в SQL?

Компании, где спрашивали
СБЕРСБЕР

Ответ от нейросети

sobes.tech AI

В SQL порядок выполнения операторов влияет на результат следующим образом:

  1. WHERE — фильтрует строки из исходной таблицы до группировки.
  2. GROUP BY — группирует отфильтрованные строки по указанным столбцам.
  3. HAVING — фильтрует уже сгруппированные данные по агрегатным условиям.

Таким образом, сначала выбираются только нужные строки, затем они группируются, и после этого группы могут быть отфильтрованы по агрегатным критериям.

Например:

SELECT department, COUNT(*)
FROM employees
WHERE salary > 50000
GROUP BY department
HAVING COUNT(*) > 5;

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