(一)分析函数语法

function_name(<argument>,<argument>...) over(<partition by clause><order by clause> <windowing_clause>);

function_name:函数名称,如count(),sum(),avg(),max(),min()等

argument : 参数

over() : 开窗函数

partition_clause:分区(分组)子句

order by clause:排序字句,数据记录排序,累计计算

windowing clause:开窗子句,定义分析函数在操作行的集合。分析函数有三种:rows、range、specifying。

(二)分析函数使用汇总

(2.1)count() over():统计分区各组中的行数,partition by可选,order by可选。

例子1:统计总人数

SQL> SELECT ename,job,COUNT(*) OVER() FROM emp;   --总计数

例子2:按照sal排序,统计总人数

SELECT ename,job,sal,COUNT(*) OVER(ORDER BY sal) FROM emp;  --按照薪资递加计数

例子3:统计各个部门的总人数

SELECT ename,job,sal,deptno,COUNT(*) OVER(PARTITION BY deptno) FROM emp;  --分组计数,统计各个部门的人数

例子4:对部门分组,对各个部门按照薪资排序并计数

SELECT ename,job,deptno,sal,COUNT(*) OVER(PARTITION BY deptno ORDER BY sal) FROM emp; --按照各个部门的薪资水平排序

(2.2)sum() over():记录分区中的总和,partition by可选,order by可选

例子1:求出所有部门的薪资总和

SELECT ename,job,sal,hiredate,SUM(sal) OVER() FROM emp;

例子2:求出各个部门薪资的累计值,按部门累计

SELECT ename,job,sal,hiredate,SUM(sal) OVER(ORDER BY deptno) FROM emp;

例子3:求出各自部门薪资的总和

SELECT ename,job,deptno,sal,hiredate,SUM(sal) OVER(PARTITION BY deptno) FROM emp

例子4:求出各部门薪资累计值

SELECT ename,job,deptno,sal,hiredate,SUM(sal) OVER(PARTITION BY deptno ORDER BY sal) FROM emp;

(2.3)avg() over():记录分区中的平均值,partition by可选,order by可选

例子1:求出所有人的平均薪资

SELECT ename,sal,hiredate,AVG(sal) OVER() FROM emp;

例子2:求出部门的累计薪资。

SELECT ename,deptno,sal,hiredate,AVG(sal) OVER(ORDER BY deptno) FROM emp;

图中红色代表10号部门人员的平均薪资,

蓝色代表10号部门与20号部门人员的平均薪资,

紫色代表10号部门与20号部门与30号部门人员的平均薪资。

例子3.求出各个部门的平均薪资

SELECT ename,deptno,sal,hiredate,AVG(sal) OVER(PARTITION BY deptno) FROM emp;

例子4:求出各个部门的平均累计薪资

SELECT ename,deptno,sal,hiredate,AVG(sal) OVER(PARTITION BY deptno ORDER BY sal) FROM emp;

(2.4)min() avg():统计分组中的最小值,partition by可选,order by可选

例子1:求所有人中薪资最小值

SELECT ename,sal,hiredate,MIN(sal) OVER() FROM emp;

例子2:求出按部门累计的最小薪资

SELECT ename,deptno,sal,hiredate,MIN(sal) OVER(ORDER BY deptno) FROM emp;

图中红圈是10号部门的最低薪资,蓝圈是10号部门与20号部门的最低薪资,紫圈是10号部门、20号部门、30号部门的最低薪资。

例子3:求出各个部门的最低薪资

SELECT ename,deptno,sal,hiredate,MIN(sal) OVER(PARTITION BY deptno) FROM emp;

例子4:按照部门求出各自部门的最小薪资,并按照部门分组后再按照薪资排序

SELECT ename,deptno,sal,hiredate,MIN(sal) OVER(PARTITION BY deptno ORDER BY sal) FROM emp;

(2.5)max() avg():统计分组中的最大值,partition by可选,order by可选。用法与上面的min() over()相似。

(2.6)row_number() over():排序,排序序号无重复值,partition by可选,order by必选

例子1:按照薪资水平从高到低输出所有人的信息

SELECT ename,deptno,sal,hiredate,row_number() OVER(ORDER BY sal DESC) FROM emp;

例子2:先按部门分组,再按照薪资水平从高到低输出所有人的信息

SELECT ename,deptno,sal,hiredate,row_number() OVER(PARTITION BY deptno ORDER BY sal DESC) FROM emp;

例子2.1:求出各个部门前2名薪资最高的人员信息

SELECT *
FROM (SELECT ENAME,
DEPTNO,
SAL,
HIREDATE,
ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY SAL DESC) RN
FROM EMP)
WHERE RN < 3;

(2.7)rank() over():跳跃排序,排序序号会有重复,partition by可选,order by必选

例子1:先按照部门降序,再按照薪资降序排序

SELECT ename,deptno,sal,hiredate,RANK() OVER(ORDER BY deptno DESC,sal DESC) FROM emp;

例子2:先按照部门分区(分组),再按照薪资升序排序

SELECT ename,deptno,sal,hiredate,RANK() OVER(PARTITION BY deptno ORDER BY sal) FROM emp;

(2.8)dense_rank() over():连续排序,排序序号会有重复,partition by可选,order by必选

例子1:先按部门排序,再只能找工资排序

SELECT ename,deptno,sal,hiredate,dense_rank() OVER(ORDER BY deptno DESC,sal DESC) FROM emp;

例子2:先按照部门分组,再按照薪资排序

SELECT ename,deptno,sal,hiredate,dense_rank() OVER(PARTITION BY deptno ORDER BY sal) FROM emp; 

(2.9)ntile(n) over():将记录平均分成n份,多出的按照次序分给前面的组。partition by可选,order by必选。

例子1:将emp表信息按照薪资从低到高分成4份

例子2:先按照部门分组,再将每个部门的数据按照薪资从低到高分成4份。

SELECT ename,deptno,sal,hiredate,NTILE(4) OVER(PARTITION BY deptno ORDER BY sal) FROM emp;

(2.10)first_value() over():取出分区中第一条记录字段的值。partition by可选 ,order by可选。

last_value() over() :取出分区中最后一条记录字段的值。partition by可选,order by可选。

(2.11)lag() over():取出前n行数据,加到当前行作为一个新的列。partition by可选,order by必选

语法为:lag(field,num,defaultValue) field为要查找的字段,num代表往前查找num行的数据,defaultValue代表没有符合条件的默认值。通过该函数可以去除前n行的数据放入到当前行的新列中。

例子1:将前一个用户的薪资作为新的列forward_sal加入到当前用户信息中。

SELECT ename,deptno,sal,hiredate,LAG(sal,1,0) OVER(ORDER BY sal) forward_sal FROM emp;

例子2:按照部门分组,再将前一个用户的薪资作为新的列forward_sal加入到当前用户信息中

SELECT ename,deptno,sal,hiredate,LAG(sal,1,0) OVER(PARTITION BY deptno ORDER BY sal) forward_sal FROM emp;

(2.12)lead() over():取出后n行数据,加到当前行作为一个新的列。partition by可选,order by必选

例子1:按照sal从小到大排序,取出后一行的sal数据添加到当前行,作为一个新的列

SELECT ename,deptno,sal,hiredate,LEAD(sal,1,0) OVER(ORDER BY sal) FROM emp;

【完】

Oracle分析函数(一)的更多相关文章

  1. Oracle分析函数入门

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  2. [转]oracle分析函数Rank, Dense_rank, row_number

    oracle分析函数Rank, Dense_rank, row_number 分析函数2(Rank, Dense_rank, row_number)   目录 ==================== ...

  3. [转]oracle 分析函数over

      oracle 分析函数over 分析函数(OVER) 目录: =============================================== 1.Oracle分析函数简介 2. O ...

  4. oracle分析函数与over()(转)

    文章参考:http://blog.csdn.net/haiross/article/details/15336313 -- Oracle分析函数入门-- 分析函数是什么? 分析函数是Oracle专门用 ...

  5. Oracle分析函数 — rank, dense_rank, row_number用法

    本文通过例子演示了Oracle分析函数 —— rank, dense_rank, row_number的用法. //首先建score表 create table score( course   nva ...

  6. 常用Oracle分析函数详解 [http://www.cnblogs.com/benio/archive/2011/06/01/2066106.html]

      学习步骤:1. 拥有Oracle EBS demo 环境 或者 PROD 环境2. copy以下代码进 PL/SQL3. 配合解释分析结果4. 如果网页有点乱请复制到TXT中查看 /*假设一个经理 ...

  7. oracle分析函数技术详解(配上开窗函数over())

    一.Oracle分析函数入门 分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计 ...

  8. Oracle分析函数——函数列表

    --------------聚合函数 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算 ...

  9. 强大的oracle分析函数

    转载:https://www.cnblogs.com/benio/archive/2011/06/01/2066106.html 学习步骤:1. 拥有Oracle EBS demo 环境 或者 PRO ...

  10. Oracle分析函数大全

    分析函数又叫开窗函数,OLAP函数等,因为有人问我用过开窗函数没,呵,什么是开窗函数,从来没听过,难道是分析函数么.哈哈,最后还真是分析函数哦!用过的东西别名也应该知道,赶上这么个事,就剽窃一眼Ora ...

随机推荐

  1. easy canvas shape with react antdesign 简单的canvas图形in antd & react

    //show: //code: import React from "react" import {findDOMNode} from 'react-dom' import { B ...

  2. 开博缘由 , 可点下看看 http://www.cnblogs.com/jshare

    记录日常用中用到.遇到的问题 实现过程,仅供参考 不定时更新 ------------------- 之前看过一个文章,大概说的是开发和用到的过的代码,可以提取出一些代码片段,长时间下来,你会发现部分 ...

  3. CentOS7运维管理笔记(12)----修改主机名

    CentOS修改主机名 CentOS7和CentOS6.5 修改主机名的方法略有不同. 通过 hostname 命令可以查看当前的主机名. 1. 临时修改主机名 通过 'hostname 新的主机名' ...

  4. 微服务架构之spring cloud ribbon

    现在负载均衡是通用的解决分压的技术方案,实现方式一般分为服务端或者客户端,服务端大部分是使用中间件实现,spring cloud ribbon 是一个客户端负载均衡组件.跟spring cloud e ...

  5. LDAP常用命令解析

    OpenLDAP常用命令讲解: ldapadd      -x   进行简单认证      -D   用来绑定服务器的DN      -h   目录服务的地址      -w   绑定DN的密码    ...

  6. laravel model relationship

    laravel支持多种模型之间的relation,对应着模型间的one2one, one2many,many2many,hasManyThrough,Polymorphic, many2many po ...

  7. 机器学习之LinearRegression与Logistic Regression逻辑斯蒂回归(三)

    一 评价尺度 sklearn包含四种评价尺度 1 均方差(mean-squared-error) 2 平均绝对值误差(mean_absolute_error) 3 可释方差得分(explained_v ...

  8. iTextSharp 使用详解(转)

    PDF文件是目前比较流行的电子文档格式,在办公自动化(OA)等软件的开发中,经常要用到该格式,但介绍如何制作PDF格式文件的资料非常少,在网上搜来搜去,都转贴的是同一段“暴力”破解的方法,代码片断如下 ...

  9. setfacl 命令的常用用法

    setfacl命令----可以用来细分linux下的文件权限. chmod命令----可以把文件权限分为u,g,o三个组,而setfacl可以对每一个文件或目录设置更精确的文件权限. 换句话说,set ...

  10. codeforces 722E Research Rover

    codeforces 722E Research Rover 题意 \(1e5*1e5\)的棋盘中有\(2000\)个坏点,初始给定一个值\(s(1<=s<=1e6)\).从棋盘左上角走到 ...