组函数及分组统计


分组函数


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 empGROUP 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_salfrom dept d,(select deptno,avg(sal) avg_salfrom empgroup by deptno having avg(sal)=(select max(avg(sal)) from emp group by deptno) ) t
where t.deptno=d.deptno;


 







转载于:https://www.cnblogs.com/yxwkf/p/5278895.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257537.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java数据生成excel_Java 数据库数据生成Excel

采用jxl.jar生成Excel项目开发注意事项&#xff1a; 1:导入从网上下载的jar包&#xff1a;mail.jar 和 activation.jar2:删掉C:\Program Files\MyEclipse\Common\plugins\com.genuitec.eclipse.j2eedt.core_10.0.0.me201110301321\data\libraryset\EE_5 下 javaee.jar中的java…

两张神图介绍python3和 2.x与 3.x 的区别

有感与第一张图, 做了第二张图.转载于:https://www.cnblogs.com/Vito2008/p/5280393.html

Java-jdbc连接数据库

1、Oracle8/8i/9i数据库&#xff08;thin模式&#xff09; Class.forName("oracle.jdbc.driver.OracleDriver").newInstance(); String url"jdbc:oracle:thin:localhost:1521:orcl"; //orcl为数据库的SID String user"test"; String…

abstract class 和 interface 区别

本文出自与&#xff1a;heipai:tsg666含有 abstract 修饰符的 class 即为抽象类&#xff0c;abstract 类不能创建的实例对象。含有 abstract 方法的类必须定义为 abstract class&#xff0c;abstract class 类中的方法不必是抽象的。abstract class 类中定义抽象方法必须在具体…

Factorial Trailing Zeroes

https://leetcode.com/problems/factorial-trailing-zeroes/ Given an integer n, return the number of trailing zeroes in n!. Note: Your solution should be in logarithmic time complexity. 解题思路&#xff1a; 再次遇见最讨厌的Math题。 开始的思路&#xff0c;结尾的…

java设计模式懒汉_java设计模式-懒汉设计模式

一、理论类加载时&#xff0c;不进行实例化&#xff0c;调用时才进行类的实例化。二、代码实现public class LazyManPattern {//1.构造方法私有化private LazyManPattern(){}//2.类加载时&#xff0c;不进行实例化private static LazyManPattern lazyManPattern;//3.创建实例化…

多视图参数传递

在iOS开发中常用的参数传递有以下几种方法&#xff1a; 采用代理模式 采用iOS消息机制 通过NSDefault存储&#xff08;或者文件、数据库存储等&#xff09; 通过AppDelegate定义全局变量&#xff08;或者使用UIApplication、定义一个单例类等&#xff09; 通过控制器属性传递转…

百年难得一见!阿里园区惊现双月争辉奇观!

9月3日晚杭州阿里园区上空突然惊现“双月争辉”奇观&#xff0c;引发路人、员工争相拍照留念狂潮。记者随后深入园区探访&#xff0c;近距离观察“双月奇观”。当晚&#xff0c;热心观众王先生提供线索。王先生路过杭州阿里巴巴园区时&#xff0c;听到有人呼喊&#xff1a;“快…

Math源码java_深入学习java源码之Math.sin()与 Math.sqrt()

深入学习java源码之Math.sin()与 Math.sqrt()native关键字凡是一种语言&#xff0c;都希望是纯。比如解决某一个方案都喜欢就单单这个语言来写即可。Java平台有个用户和本地C代码进行互操作的API&#xff0c;称为JNInative关键字告诉编译器(其实是JVM)调用的是该方法在外部定义…

路由控制器Express的路由控制方法

MVC中的C控制器 express的路由控制方法&#xff1a;1.创建路由规则 var express require(‘express’); var router express.Router(); /* get home page.*/ router.get(/, function(req,res){ res.render(index, title:express); }); module.exports router; 服务器在开始…

URAL 1146 Maximum Sum(最大子矩阵的和 DP)

Maximum Sum 大意&#xff1a;给你一个n*n的矩阵&#xff0c;求最大的子矩阵的和是多少。 思路&#xff1a;最開始我想的是预处理矩阵&#xff0c;遍历子矩阵的端点&#xff0c;发现复杂度是O(n^4)。就不知道该怎么办了。问了一下&#xff0c;是压缩矩阵&#xff0c;转换成最大…

基于 axios 的 Vue 项目 http 请求优化

对于需要大量使用 http 请求的项目&#xff0c;我们通常会选择对 http 请求的方法进行二次封装&#xff0c;以便增加统一的拦截器&#xff0c;或者统一处理阻止重复提交之类的逻辑。Vue.js 的项目中我们选择使用了 axios 这样一个 http 库&#xff0c;下面也就简述下基于 axios…

Spring 事务配置5种方式

Spring配置文件中关于事务配置总是由三个组成部分&#xff0c;分别是DataSource、TransactionManager和代理机制这三部分&#xff0c;无论哪种配置方式&#xff0c;一般变化的只是代理机制这部分。 DataSource、TransactionManager这两部分只是会根据数据访问方式有所变化&…

java中主线程首先执行_java经典面试题:子线程先运行30次主线程,主线程40次,如此循环50次?...

最近偶遇这道题&#xff0c;网上相似的题都是循环次数不一样。然而我百度搜到的论坛或者博客感觉都不太对&#xff0c;运行有穿插。请给出正确结果。我们假使所有人都引入了业务对象。并且我有疑问&#xff1f;感觉题目本意不是new Thread()放在前面。网上有人做法是用标志位防…

[翻译]Feedback on the Go Challenge solutions

第一次Go Challenge比赛&#xff0c;中国区只有3人参赛。 赛后收到邮件&#xff0c;是一个审阅者的反馈&#xff0c;“Feedback on the Go Challenge solutions”&#xff0c;摘录如下&#xff1a; 保持简单粗暴 一个语义单元一个文件即可&#xff0c;不要像Java那样一个文件就…

黑客宣称掌握了600多万个Instagram账号的信息

据外媒报道&#xff0c;上周早些时候&#xff0c;歌手兼演员赛琳娜戈麦斯因Instagram账号被盗而发出大量来自前男友贾斯汀比伯的裸照。不过当时很快赛琳娜就拿回了对账号的控制权并删掉了这些裸照。就在大家以为这件事情已经平息的时候&#xff0c;Instagram却被曝光了一个极为…

java apache.poi_Java Apache POI

我正在努力从excel文档中读取数据,该文档每两周更新一次,大约有50,000行数据,在开始新工作表之前可能会达到大约120,000.我正在使用Apache POI来获取数据.我在下面得到了这个例外,但我认为最重要的一个例外是引起&#xff1a;java.lang.OutOfMemoryError&#xff1a;Java堆空间…

Hibernate逍遥游记-第2章-使用hibernate.properties

1. 1 package mypack;2 3 import org.hibernate.*;4 import org.hibernate.cfg.Configuration;5 import java.util.*;6 7 public class BusinessService{8 public static SessionFactory sessionFactory;9 10 /** 初始化Hibernate&#xff0c;创建SessionFactory实例 */1…

奇怪吸引子---Aizawa

奇怪吸引子是混沌学的重要组成理论&#xff0c;用于演化过程的终极状态&#xff0c;具有如下特征&#xff1a;终极性、稳定性、吸引性。吸引子是一个数学概念&#xff0c;描写运动的收敛类型。它是指这样的一个集合&#xff0c;当时间趋于无穷大时&#xff0c;在任何一个有界集…

C#打印图片

打印的原理是&#xff1a;生成mdi文件&#xff0c;系统碰到mdi的时候会自动以打印的方式处理。所以&#xff0c;不管用什么模板&#xff0c;什么方式&#xff1b;能在PrintPage事件处理中,生成一张要打印内容的图片就OK了! C#实现打印源码如下&#xff1a; #region 打印 …