数据库中的having语句_sql的having语句

数据库中的having语句_sql的having语句SQL语句HAVING的用法HAVING语句通常与GROUPBY子句及聚集函数COUNT,AVG,SUM,MAX,MIN语句联合使用,用来过滤由GROUPBY语句返回的记录集,通常跟在GROUPBY后边作用相当于WHERE。where子句后边是指定行所对应的条件,并且不能含有聚集函数,而HAVING后边是指定组所对应的条件,可以含有聚合函数。HAVING语句的存在弥补了WHERE关键字不能与聚集函数联合使用的不足。我们可以这样理解:where筛选的是行(一个元组),而having筛选的是组(多

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

数据库查询语句 HAVING的用法

HAVING语句通常与GROUP BY子句及聚集函数COUNT,AVG,SUM,MAX,MIN语句联合使用,用来过滤由GROUP BY语句返回的记录集,通常跟在GROUP BY后边作用相当于WHERE。

where子句后边是指定行所对应的条件,并且不能含有聚集函数,而HAVING后边是指定组所对应的条件,可以含有聚合函数。HAVING语句的存在弥补了WHERE关键字不能与聚集函数联合使用的不足。
我们可以这样理解:where筛选的是行(一个元组),而having筛选的是组(多行元组)。

GROUP BY子句 :
将查询结果按某一列或多列的值分组,值相等的为一组。如果未对查询结果分组,聚集函数将作用于整个查询结果。分组后聚集函数将作用于每一个组,即每一组都有一个函数值。如果分组后还要求按一定的条件对这些组进行筛选,最终只输出满足指定条件的组,则可以使用 HAVING短语指定筛选条件。
聚合/聚集函数:
COUNT(*)统计元组个数 COUNT([ DISTINCTIALL]<列名>)统计列中值的个数
SUM([ DISTINCT JALLI<列名>)计算一列值的总和(此列必须是数值型)
AVG( LDISTINCTIALL]k列名>)计算一列值的平均值(此列必须是数值型)
MAX([ DISTINCTIALL]<列名>)求一列值中的最大值
MIN([DSTⅠ NCTIALL]<列名>)求一列值中的最小值

HAVING使用举例
例一 显示每个地区的总人口数和总面积.仅显示那些面积超过1000000的地区
SELECT region, SUM(population), SUM(area)
FROM bbc
GROUP BY region
HAVING SUM(area)>1000000
例二 查询部门平均薪资高于全体员工薪资的部门名称,及部门平均薪资
SELECT Dname SUM(salary) as 部门平均薪资
FROM department
GROUP BY Dname
HAVING SUM(area)> (SELECT SUM(salary)
FROM department )
例三 查询班级平均成绩大于75的班级信息。
SELECT Class SUM(grade)
FROM department
GROUP BY Class
HAVING SUM(grade)> 75

含有HAVING子句的SQL语句执行顺序如下:
(1)where子句查找符合条件的数据;
(2)使用group by 子句对数据进行分组;
(3)对每个分组运行聚集函数计算;
(4)用having 子句去掉不符合条件的组。
注: having 子句中的元素必须出现在select列表中。

——————————————————完————————————————-

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197667.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • wxpython中文教程_wxPython快速入门教程

    wxpython中文教程_wxPython快速入门教程1第一个应用程序“Hello,world”importwxapp=wx.App(False)frame=wx.Frame(None,wx.ID_ANY,”HolloWorld”)frame.Show(True)app.MainLoop()2是创造一个wx.App实例。参数是“False”的意思是不将stdout和stderr重定向到一个窗口,这个参数是“True”对这个例子没有…

    2022年5月21日
    25
  • getmethod方法什么意思_getstring方法

    getmethod方法什么意思_getstring方法getMethod方法要注意的地方:类对象.getMethod(mName,HttpServletRequest.class,HttpServletResponse.class);第一个参数是mName“方法名称”第二个参数是“方法参数的类对象”//这个就是为什么他是.class的原因,为什么参数是类对象?因为这个是Java规定的举个例子  这是一个抽取出的通用的servlet(页面请求经过的第…

    2025年11月24日
    4
  • jBox属性_canvas的属性

    jBox属性_canvas的属性<scriptsrc=”https://code.jquery.com/jquery-3.3.1.min.js”></script><scriptsrc=”https://cdn.jsdelivr.net/gh/StephanWagner/jBox@v0.4.9/Source/jBox.min.js”></script><linkh…

    2025年5月22日
    2
  • TypeScript(5)类、继承、多态「建议收藏」

    TypeScript(5)类、继承、多态「建议收藏」前言对于传统的JavaScript程序我们会使用函数和基于原型的继承来创建可重用的组件,但对于熟悉使用面向对象方式的程序员使用这些语法就有些棘手,因为他们用的是基于类的继承并且对象是由类构建出来

    2022年8月7日
    4
  • 数据结构之循环链表建议收藏

    一循环链表基础在单链表中,有了头结点,我们可以在O(1)时间访问到第一个节点,但如果要访问最后一个节点却需要O(n)的时间,因为我们需要对整个链表进行一次遍历。在循环链表中,我们可以借助尾节点来实

    2021年12月19日
    41
  • Landsat8数据不同波段组合的用途「建议收藏」

    Landsat8数据不同波段组合的用途「建议收藏」2013年2月11日发射的Landsat系列最新卫星Landsat8,携带有OLI陆地成像仪和TIRS热红外传感器,Landsat8的OLI陆地成像仪包括9个波段,OLI包括了ETM+传感器所有的波段,为了避免大气吸收特征,OLI对波段进行了重新调整,比较大的调整是OLIBand5(0.845–0.885μm),排除了0.825μm处水汽吸收特征;OLI全色波段Band8波段范围较窄,这种方式

    2022年7月23日
    12

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号