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 фильтрует группы по количеству.