组函数及分组统计[通俗易懂]

组函数及分组统计

大家好,又见面了,我是全栈君。

分组函数

SQL中经常使用的分组函数

    Count(): 计数

    Max():求最大值

    Min():求最小值

    Avg():求平均值

    Sum():求和

-- 统计emp表中的人数
select count(*) from emp; 

-- 统计获得奖金的人数
select count(comm) from emp;

-- 求全部雇员的最低工资
select min(sal) from emp;

-- 求全部雇员的最高工资
select max(sal) from emp;

-- 求部门编号为20的雇员的平均工资和总工资
select avg(sal),sum(sal) from emp where deptno = 20;

分组统计查询

语法格式

SELECT {DISTINCT}*|查询列1 别名1,查询列2 别名2……

FORM 表名称1 别名1,表名称2 别名2,……

{WHERE 条件表达式}

{GROUP BY 分组条件}

{ORDERBY  排序字段 ASC|DESC,排序字段 ASC|DESC,……}

-- 统计出每一个部门的人数
select deptno,count(empno) from emp group by deptno;

-- 求出每一个部门的平均工资
select deptno, avg(sal) from emp group by deptno;

统计每一个部门的最高工资,以及获得最高工资的雇员姓名

假设写成

SELECT ename,max(sal)
 FROM emp
 GROUP BY deptno

Oracle会提示第 1 行出现错误:

ORA-00979: 不是 GROUP BY 表达式

以上代码在运行过程中出现错误,是由于:

1. 假设程序中使用了分组函数。则在下面两种情况下能够正常查询结果:

      程序中存在了GROUP BY,并指定了分组条件。这样能够将分组条件一起查询出来

      假设不使用GROUP BY,则仅仅能单独地使用分组函数

2.使用分组函数时,查询结果列不能出现分组函数和分组条件之外的字段


综上所述,我们在进行分组统计查询时有遵循这样一条规律:

出如今字段列表中的字段。假设没有出如今组函数中。就必然出如今GROUP BY 语句的后面


-- 统计出每一个部门的最高工资。及最高工资的雇员姓名
select deptno, ename,sal from emp where sal in(select max(sal) from emp group by deptno);

组函数及分组统计[通俗易懂]

-- 查询出每一个部门的部门名称。及每一个部门的雇员人数
select d.dname, count(e.empno)
from emp e, dept d
where e.deptno = d.deptno
group by d.dname

求出平均工资大于2000的部门编号和平均工资

刚開始学习的人非常easy错误地写成将工资大于2000的条件写在where的后面

SELECT deptno,avg(sal)  FROM emp  WHERE avg(sal)>2000   GROUP BYdeptno<span style="font-family:SimSun;"></span>

系统出现例如以下错误提示:

ORA-00934: 此处不同意使用分组函数

-- 求出平均工资大于2000的部门编号和平均工资
select e.deptno, avg(sal)
from emp e, dept d
where e.deptno = d.deptno
having avg(sal) > 2000
group by e.deptno;

规则:WHERE 仅仅能对单条记录限制(过滤),having是对分组进行过滤

分组函数仅仅能在分组中使用。不能在WHERE语句之中出现。假设要指定分组条件,则仅仅能通过另外一种条件的指令:HAVING

-- 显示非销售人员工作名称以及从事同一工作雇员的月工资总和,而且要满足从事同一工作的雇员的月工资合计大于$5000,输出结果按月工资合计升序排列
select e.job, sum(e.sal) sum_sal
from emp e
where e.job <> 'SALESMAN'
group by e.job
having sum(e.sal) > 5000
order by sum_sal;

分组的简单原则:
     仅仅要一列上存在反复内容才有可能考虑到用分组查询

注意:

     分组函数能够嵌套使用,可是在组函数嵌套使用的时候不能再出现分组条件的列名

例:求平均工资最高的部门编号、部门名称、部门平均工资

第一步:

select deptno, avg(sal) from emp group by deptno;

组函数及分组统计[通俗易懂]

第二步:

select deptno, max(avg(sal)) from emp group by deptno;

ORA-00937: 不是单组分组函数

第三步:去掉查找结果中的deptno列

select max(avg(sal)) from emp group by deptno;

组函数及分组统计[通俗易懂]

逐步完毕后:

select d.deptno, d.dname, t.avg_sal
  from dept d,
   (select deptno,avg(sal) avg_sal
      from emp
       group by deptno having avg(sal)=
          (select max(avg(sal)) from emp group by deptno) 
   ) t
where t.deptno=d.deptno;


组函数及分组统计[通俗易懂]

 

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/115656.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 免费的ssl证书申请_公需课怎么申请证书

    免费的ssl证书申请_公需课怎么申请证书第一步:在阿里云上申请免费的https证书先点击Symantec然后选择1个域名然后选择免费型DVSSL第二步:我的订单页面完成信息的补全第三步:点击详情查看DNS信息,并且配置DNS信息第四步:下载证书,上传到nginx服务器第五步:配置nginx代理,并重启nginx服务第六步:访问https的接口或者页面,查看是否配置正确。

  • phpstorm 2021.11.3 激活码(JetBrains全家桶)[通俗易懂]

    (phpstorm 2021.11.3 激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

  • 二进制中的加减法_二进制数的加减运算

    二进制中的加减法_二进制数的加减运算二进制的加减法1)二进制加法(1)BinaryAddition)Sincebinarynumbersconsistofonlytwodigits0and1,sotheiradditionisdifferentfromdecimaladdition.Additionofbinarynumberscanbedonefollowingcer…

  • S3C2440移植uboot之支持NANDFLASH操作

    S3C2440移植uboot之支持NANDFLASH操作上一节我们移植了uboot,S3C2440移植uboot之支持NORFLASH。这节我们继续移植,支持NANDFLASH。之前由于nand部分报错,直接注释了 u-boot-2012.04.01\include\configs\smdk2440.h中的#defineCONFIG_CMD_NAND。现在我们去掉注释,重新编译。报错如下是我们没有定义CONFIG_S3C2410导致的可以…

  • 解决keil注册机和编译错误的问题2020-12-28

    解决keil注册机和编译错误的问题2020-12-28https://72k.us/file804/10165491-428107594这个地址的注册机验证可以有效到2032年。当以前的代码可以编译通过,但是新安装的keil确有大量的编译错误的时候。这个时候可能的原因是配置上没有设置C99Mode。勾选C99Mode是解决这个问题的手段之一。…

  • python画心形代码大全_七夕,程序员的表白代码「建议收藏」

    python画心形代码大全_七夕,程序员的表白代码「建议收藏」七夕快到了,表白素材赶紧先准备好。。。0、委婉的表白Python代码:importstringl=string.ascii_letterss=[]s.append(l[34])s.append(l[11])s.append(l[14])s.append(l[21])s.append(l[4])s.append(l[24])s.append(l[14])s.append(l[20])s….

发表回复

您的电子邮箱地址不会被公开。

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