简单总结一下对于数据的分组和分组函数。

本文所举实例,数据来源oracle用户scott下的emp,dept ,salgrade 3表:数据如下:

一、分组函数

1、sum()求和函数、max()求最大值函数、min()求最小值函数、avg()求平均值函数、count()求总行数函数

Expression:   sum(column)、max(cloumn)、min(cloumn)、avg(column)、count(column)   其中column都是字段名称

Example:

select avg(sal),max(sal),min(sal),sum(sal),count(sal) from emp;

2、distinct关键字:英译有区别的,用于对同一个列去除重复值: Expression:      dinsticnt(column)

Example:

select distinct deptno from emp;

3、wm_concat函数:行转列函数,将列值以逗号作为分割显示在一行的函数。    Expression(column)

Example:

select wm_concat(ename) from emp;

二、数据分组

1、group by分组子句:和分组函数结合使用,对其他条件进行分组,如求每个部门的平均工资,平均工资用分组函数avg,每个部门则需用group by 分组

Example:

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

注意:group by字句中的条件必须是所有的除了分组以外的所有列才不会出错,并且必须和分组函数结合使用否则没有分组的意义,并且会报错。

2、having 子句:如果查询条件中有分组函数,此时不能使用where子句,替换为having子句,用于对分组后的结果进行过滤。

Example:

可以看出where子句不允许使用分组函数

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

三、经典实例分析:

1、求部门平均薪水的等级和求部门平均的薪水等级。

这里多用到一个薪水等级的表salgrade:

select deptno,avg_sal,grade from (select deptno,avg(sal) avg_sal from emp group by deptno) a join salgrade on
(a.avg_sal between losal and hisal);

解析:第一问:由问题可知需要求三个值,deptno,avg_sa,grade,求解的是平均薪水的等级,那么先求部门的平均薪水,用分组函数和group_by子句,分组条件很明显deptno,将此结果看做一个新表a,其中可以查询到deptno和avg_sal,接下来还有一个等级需要求解,直接join表salgrade,条件也很明显,平均工资在低工资和高工资之间就可以了,加入条件后即可查询出对应的grade等级

select deptno,avg(grade) from (select deptno,grade from emp e join salgrade on e.sal between losal and hisal) group by deptno; 

第二问:由题意分析出需要求解2个值deptno,avg(grade),平均 的薪水等级重心是等级,划分为小问题先求解每个员工薪水等级,从emp表联合salgrade表查询,条件是每个员工工资在losal和hisal之间,这样就求出了部门号和每个员工的工资等级,那么再求平均等级只需要avg函数,又题目求得是每个部门的工资等级,只需要分组即可,分组条件deptno。

注:此类题型注重对问题的解读,分析出求解几个值,再使用传统思路将大问题划分为若干小问题,由小及大解决即可。

                                                              2018-08-10  09:27:27

Oracle分组函数以及数据分组的更多相关文章

  1. MySQL聚合函数与数据分组

    我们最常需要的是汇总数据而不是把他们实际检索出来 确定表中行数(或满足某个条件或包含某个特定值的行数) 确定表中行组的和 找出表列(或所有行或特定列)的最大值,最小值和平均值 聚集函数是运行在行组上, ...

  2. oracle wm_concat函数 列转行 分组函数

    (1)select mark, wm_concat(status) from DISSENT_INFO t GROUP BY mark; 查出来的数据 mark     status 222      ...

  3. Oracle 分组函数

    分组函数的介绍 分组函数作用于一组数据,并对一组数据返回一个值. (引用网上的一张图) 分组函数的使用规则 SELECT [column,] group_function(column) FROM t ...

  4. Oracle学习笔记_05_分组函数

    组函数:avg  sum  max  min   count group by having group by 增强:rollup      cube     grouping      groupi ...

  5. mysql基础教程(二)-----分组函数、多表查询、常见函数

    分组函数 什么是分组函数 分组函数作用于一组数据,并对一组数据返回一个值. 组函数类型 • AVG() • COUNT() • MAX() • MIN() • SUM() 组函数语法 AVG(平均值) ...

  6. Oracle_SQL函数-分组函数

    分组函数 什么是分组函数 分组函数作用于一组数据,并对一组数据返回一个值 组函数类型:主要有6种 AVG - 平均 COUNT - 计数 MAX - 最大 MIN - 最小 SUM - 求和 STDD ...

  7. mysql分组函数与查询

    Ⅰ.分组函数的分类: max():最大值 min():最小值 sum():和 avg():平均值 count():计算非空的个数 这些都是通用的,sqlserver.oracle.mysql都是一样的 ...

  8. Mysql高手系列 - 第9篇:详解分组查询,mysql分组有大坑!

    这是Mysql系列第9篇. 环境:mysql5.7.25,cmd命令中进行演示. 本篇内容 分组查询语法 聚合函数 单字段分组 多字段分组 分组前筛选数据 分组后筛选数据 where和having的区 ...

  9. oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数

        花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...

随机推荐

  1. 第一章 Java常用集合类总览

    1.Java最常用的集合类 Collection接口 List接口(允许有重复元素):ArrayList.LinkedList.Vector.Stack Set接口(不允许有重复元素,可用于去重操作) ...

  2. MSSQL工作中常用的小技巧

    大概看了一下有接近二十天自己没有写博客了,一来是因为国庆之前公司工作总会比较繁杂一点,国庆自己也需要休息,二来是因为学习一些新的东西,公司写了一天SQL回家看了看以前的笔记,感觉还挺不错,贴出来供大家 ...

  3. HTTP请求方法 GET POST【总结】

    HTTP 8种请求方法概述 HTTP/1.1协议中共定义了八种方法(有时也叫"动作"),分别为:get,post,put, options,head,delete,trace,co ...

  4. Gson 使用总结 高级用法

    Gson基本用法 参考:http://www.jianshu.com/p/e740196225a4 Gson提供了fromJson() 和toJson() 两个直接用于解析和生成的方法,前者实现反序列 ...

  5. jQuery EasyUI 教程-Tooltip(提示框)

    <!DOCTYPE html> <html> <head> <title>jQuery Easy UI</title> <meta c ...

  6. HTML-<td> 标签的 valign 属性

    <html> <body> <table border="1" style="height:200px"> <tr&g ...

  7. python 插入数据获取id

    python 插入数据获取id 学习了:https://blog.csdn.net/qq_37788558/article/details/78151972 commit之前获取 cursor.las ...

  8. (转)Unity中protobuf的使用方法

    在移动手机游戏开发中,目前Unity3D已成为比较主流的开发技术. 那么对于客户端服务器协议的打解包,我们有3中常用的处理方式: 1.自定义结构体:在协议中直接传输代码中自定义的结构体:这种方式的坏处 ...

  9. Immediately-Invoked Puzzler

    The Poplar Puzzle-makers weren’t too impressed. They barely noticed your simple and beautiful array ...

  10. /etc/rc.d/init.d/functions文件详细分析

    /etc/rc.d/init.d/functions文件详细分析 functions这个脚本是给/etc/init.d里边的文件使用的(可理解为全局文件). 提供了一些基础的功能,看看里边究竟有些什么 ...