English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Основное руководство по SQLite

Дополнительное руководство по SQLite

Программный интерфейс SQLite

Предложение HAVING в SQLite

Предложение 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