Sobes.tech
Back to questions
Middle
3

Агрегирующие функции (SUM, COUNT и т.д.) — где их можно использовать в SQL-запросе? В чём разница между WHERE и HAVING при использовании агрегирующих функций?

Companies where asked
Evrone

Answer from AI

sobes.tech AI

Агрегирующие функции (SUM, COUNT, AVG, MAX, MIN и т.д.) используются в SQL для вычисления сводных значений по группам данных. Их можно применять в:

  • SELECT — чтобы получить агрегированные значения
  • HAVING — для фильтрации групп по агрегатам

Разница между WHERE и HAVING:

  • WHERE фильтрует строки до группировки, то есть работает с исходными данными.
  • HAVING фильтрует уже сгруппированные данные, то есть работает с результатами агрегатных функций.

Пример:

SELECT department, COUNT(*) as employee_count
FROM employees
WHERE salary > 50000  -- фильтруем сотрудников с зарплатой > 50k
GROUP BY department
HAVING COUNT(*) > 10    -- выбираем отделы с более чем 10 сотрудниками

Здесь сначала WHERE отбирает строки, потом происходит группировка, а HAVING фильтрует группы по количеству.