sql语句中 having与where区别

本文深入探讨了SQL中HAVING语句的用法,特别是它如何与GROUP BY语句结合,用于过滤分组后的数据集。通过实例,展示了如何使用HAVING来设定平均分数的阈值,以及如何在WHERE子句限制的基础上进一步筛选结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

HAVING语句通常与GROUP BY语句联合使用,用来过滤由GROUP BY语句返回的记录集。

HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。

 

 

CREATE TABLE `tp5_student` (

  `id` int(11) DEFAULT NULL,

  `no` int(11) DEFAULT NULL COMMENT '学号',

  `course` varchar(255) DEFAULT NULL COMMENT '课程',

  `score` int(11) DEFAULT NULL COMMENT '分数'

) ENGINE=InnoDB DEFAULT CHARSET=utf8

 

SELECT id,no, COUNT(course) as numcourse, AVG(score) as avgscore

 

FROM tp5_student

 

GROUP BY no

 

 

SELECT id,no, COUNT(course) as numcourse, AVG(score) as avgscore

 

FROM tp5_student

 

GROUP BY no HAVING  AVG(score)>=85

 

 

 

 

SELECT id,no, COUNT(course) as numcourse, AVG(score) as avgscore

 

FROM tp5_student

 

WHERE  id>3

 

GROUP BY no

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

芝麻开门2015

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值