HAVING 子句
在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与聚合函数一起使用。
HAVING 子句可以让咱们筛选分组后的各组数据。
SQL HAVING 语法
SQL HAVING 语法 SELECT column_name, aggregate_function(column_name)
FROM table_name
WHERE column_name operator value
GROUP BY column_name
HAVING aggregate_function(column_name) operator value;
演示database
在本教程中,咱们将使用 liulianjiangcsdn 样本database。
下面是选自 “Websites” 表的数据:
+----+--------------+---------------------------+-------+---------+
| id | name | url | alexa | country |
+----+--------------+---------------------------+-------+---------+
| 1 | Google | https://www.google.cm/ | 1 | USA |
| 2 | 淘宝 | https://www.taobao.net/ | 13 | CN |
| 3 | liulianjiangcsdn教程 | http://blog.csdn.net/qq441540598/ | 4689 | CN |
| 4 | 微博 | http://weibo.net/ | 20 | CN |
| 5 | Facebook | https://www.facebook.net/ | 3 | USA |
| 7 | stackoverflow | http://stackoverflow.net/ | 0 | IND |
+----+---------------+---------------------------+-------+---------+
下面是 “access_log” 网站访问记录表的数据:
mysql> SELECT * FROM access_log;
+-----+---------+-------+------------+
| aid | site_id | count | date |
+-----+---------+-------+------------+
| 1 | 1 | 45 | 2023-05-10 |
| 2 | 3 | 100 | 2023-05-13 |
| 3 | 1 | 230 | 2023-05-14 |
| 4 | 2 | 10 | 2023-05-14 |
| 5 | 5 | 205 | 2023-05-14 |
| 6 | 4 | 13 | 2023-05-15 |
| 7 | 3 | 220 | 2023-05-15 |
| 8 | 5 | 545 | 2023-05-16 |
| 9 | 3 | 201 | 2023-05-17 |
+-----+---------+-------+------------+
9 rows in set (0.00 sec)
SQL HAVING 实例
现在咱们想要查找总访问量大于 200 的网站。
咱们使用下面的 SQL 语句:
实例
执行以上 SQL 输出结果请在输出结果查看
SELECT Websites.name, Websites.url, SUM(access_log.count) AS nums FROM (access_log
INNER JOIN Websites
ON access_log.site_id=Websites.id)
GROUP BY Websites.name
HAVING SUM(access_log.count) > 200;
+------------------+------------------------------+------+
| name | url | nums |
+------------------+------------------------------+------+
| Facebook | https://www.facebook.net/ | 750 |
| Google | https://www.google.cm/ | 275 |
| liulianjiang教程 | http://www.liulianjiang.net/ | 521 |
+------------------+------------------------------+------+
现在咱们想要查找总访问量大于 200 的网站,并且 alexa 排名小于 200。
咱们在 SQL 语句中增加一个普通的 WHERE 子句:
实例
SELECT Websites.name, SUM(access_log.count) AS nums FROM Websites
INNER JOIN access_log
ON Websites.id=access_log.site_id
WHERE Websites.alexa < 200
GROUP BY Websites.name
HAVING SUM(access_log.count) > 200;
执行以上 SQL 输出结果请在输出结果查看
+----------+------+
| name | nums |
+----------+------+
| Facebook | 750 |
| Google | 275 |
+----------+------+
本专栏所有文章
寄语
本文有榴莲酱CSDN原创,欢迎点赞、转载,博客地址:https://blog.csdn.net/qq441540598
- 现在的我很乖,没有谈恋爱。其实孩子气,也没什么不好,人总有一天会长大,何必成熟太早,失去太早。
- 勇于正视自己的缺点并从中站立起来的人才是生活的强者。
- 痛苦是没有生在一个完整的家庭,没有一个幸福的童年。
- 你是父母的希望,也是教师国家社会的希望。你是有责任的,你应当承担起你的责任,你能做到。
- 不要等待运气降临,应该去努力掌握知识。一弗莱明知识,对大多数涉猎的人来说,只是一种货币。节约和劳动,是人类最真实的二位医师。社会就是书,事实就是教材。