English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Предложение HAVING позволяет指定 условия для фильтрации групп, которые должны出现在 конечных результатах.
Предложение WHERE устанавливает условия на выбранных столбцах, а предложение HAVING устанавливает условия на группах, созданных предложением GROUP BY.
Вот位置 предложения HAVING в SELECT-запросе.
SELECT FROM WHERE GROUP BY HAVING ORDER BY
Предложение HAVING должно следовать за предложением GROUP BY в запросе и, если используется, должно предшествовать предложению ORDER BY. Вот грамматика предложения SELECT, включая предложение HAVING.
SELECT column1, column2 FROM table1, table2 WHERE [conditions] GROUP BY column1, column2 HAVING [conditions] ORDER BY column1, column2
Рассмотрим таблицу COMPANY с следующим набором записей.
ID NAME AGE ADDRESS SALARY ---------- ---------- ---------- ---------- ---------- 1 Paul 32 California 20000.0 2 Allen 25 Texas 15000.0 3 Teddy 23 Норвегия 20000.0 4 Mark 25 Rich-Mond 65000.0 5 David 27 Texas 85000.0 6 Kim 22 South-Hall 45000.0 7 James 24 Houston 10000.0 8 Paul 24 Houston 20000.0 9 James 44 Норвегия 5000.0 10 James 45 Texas 5000.0
Ниже приведен пример, который будет показывать записи с количеством имен, менее 2.
sqlite > SELECT * FROM COMPANY GROUP BY name HAVING count(name) < 2;
Это вызовет следующий результат.
ID NAME AGE ADDRESS SALARY ---------- ---------- ---------- ---------- ---------- 2 Allen 25 Texas 15000 5 David 27 Texas 85000 6 Kim 22 South-Hall 45000 4 Mark 25 Rich-Mond 65000 3 Teddy 23 Норвегия 20000
Ниже приведен пример, который будет показывать записи с количеством имен, превышающим 2.
sqlite > SELECT * FROM COMPANY GROUP BY name HAVING count(name) > 2;
Это вызовет следующий результат.
ID NAME AGE ADDRESS SALARY ---------- ---------- ---------- ---------- ---------- 10 James 45 Texas 5000