mysql having 子句
HAVING 子句用来筛选分组后的各组数据。
一、HAVING 子句语法
SELECT 列名, 聚合函数(列名) FROM 表名 WHERE 条件表达式 GROUP BY 列表 HAVING 聚合函数(列名) operator value;
二、数据库实例
数据库有如下 score 表:
data:image/s3,"s3://crabby-images/54e94/54e943836ce38075e5d8d980470eb3658fe9f39a" alt=""
数据库还有如下 student 表:
data:image/s3,"s3://crabby-images/0e5e0/0e5e0be834b754dbd3b9e62cbd63305c5653ec4a" alt=""
一)不加 WHERE 子句
统计总成绩大于 200分的学生记录:
SELECT student_id,sum(score.score) as total_score FROM score INNER JOIN student ON score.student_id=student.ID GROUP BY student_id HAVING sum(score.score)> 200;
执行以上 SQL 语句,可得到如下结果集:
data:image/s3,"s3://crabby-images/bcbf4/bcbf4bd0913ce507cc25b097ea7bd9ec957057a5" alt=""
二)加 WHERE 子句
统计总成绩大于 200分、并且国籍是中国的学生记录:
SELECT student_id,sum(score.score) as total_score FROM score INNER JOIN student ON score.student_id=student.ID WHERE score.country = 'CN'
执行以上 SQL 语句,可得到如下结果集:
data:image/s3,"s3://crabby-images/13bfc/13bfcb17fb8dea2d690fe601e6a294b77c332f00" alt=""