sql语句中having的作用是?

 我来答
浪尖讨生活9z
高粉答主

2018-10-04 · 每个回答都超有意思的
知道小有建树答主
回答量:298
采纳率:100%
帮助的人:13.5万
展开全部

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

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

语法:

SELECT column1, column2, ... column_n, aggregate_function (expression)
FROM tables
WHERE predicates
GROUP BY column1, column2, ... column_n
HAVING condition1 ... condition_n;

同样使用本文中的学生表格,如果想查询平均分高于80分的学生记录可以这样写:

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

FROM student

GROUP BY id

HAVING AVG(score)>=80;

在这里,如果用WHERE代替HAVING就会出错。

扩展资料:

结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名

结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。

参考资料:SQL百度百科

lemonlms987
2012-04-06 · TA获得超过277个赞
知道小有建树答主
回答量:163
采纳率:0%
帮助的人:77.6万
展开全部
having称为分组滤过条件,也就是说是分组需要的条件,所以必须与group by联用
也就是说,聚合函数计算的结果可以当条件来使用,因为它无法放在where里,只能通过having这种方式来解决。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
AaronWo
2012-04-07 · TA获得超过114个赞
知道答主
回答量:45
采纳率:0%
帮助的人:28.6万
展开全部
如果需要对组函数的结果作为条件,那么不能使用where子句,必须使用having子句。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
晓等2
2019-03-04
知道答主
回答量:1
采纳率:0%
帮助的人:752
展开全部
聚合函数通过作用于一组数据而只返回一个单个值
WHERE关键字不能处理一个数值大小的比较,而HAVING语句可以
故HAVING语句的存在弥补了WHERE关键字不能与聚合函数联合使用的不足。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
shearer120
2021-01-21 · TA获得超过485个赞
知道答主
回答量:5
采纳率:0%
帮助的人:5.8万
展开全部

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(6)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式