by max over partition_Oracle分析函数小结(over()、over(order by ...)、over(partition by...))...
以前测试的时候需要验证些报表取数是否正确,会有些统计要用到分析函数,所以就学习了一下,下面先给大家讲讲over()、over(order by ...)、over(partition by...)
首先准备工作:先安装oracle服务端,然后建用户、建表空间、建表、造数据
如我建的建单一点的成绩表score,主要存储了班级编号、学生编号、学生姓名、成绩
-- Create table
create table SCORE
(
class_id VARCHAR2(28),
s_id VARCHAR2(4),
s_name VARCHAR2(6),
score NUMBER(4,1)
)
tablespace ASPROD
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 64
minextents 1
maxextents unlimited
);
-- Add comments to the table
comment on table SCORE
is '成绩';
-- Add comments to the columns
comment on column SCORE.class_id
is '班级编号';
comment on column SCORE.s_id
is '学生编号';
comment on column SCORE.s_name
is '学生姓名';
comment on column SCORE.score
is '成绩';
然后插入数据
CLASS_IDS_IDS_NAMESCORE
1010101李四80.0
2010102陆小凤78.0
3010103王五92.0
4010104杨丹83.0
5010105张三65.0
6020201杨艳98.0
7020202黄明94.0
8020203刘晓87.0
9020204陈诚77.0
10020205唐煌88.0
11030301苏三91.0
12030302戴二67.0
13030303林森56.0
14030304袁奎98.0
一、
下面来说一下分析函数:分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行。
Exp:
Sql代码
select t.s_id,t.s_name,sum(t.score) from score t;
执行上面的sql会报:ORA-00937:不是单组分组函数
结论:聚合函数只能返回1行值。
Sql代码:
select t.s_id, t.s_name, sum(t.score) over() sum from score t;
sum的结果都是总的sum(score)的值
返回的结果:
结论:这就是每个组返回多行。
二、
Over()、over(order by...)与over(partition by ...)之前的区别分析函数over()用在聚合函数(max(),sum()....)后面,可返回多行所有结果的聚合值。
如上sql:select t.s_id,t.s_name,sum(t.score) over() sum from score t;over(order by...)用在聚合函数(max(),sum()....)后面,可返回根据排序结果进行统计到当前行的聚合值(即“连续”统计)
exp:
sql代码:
select t.class_id,
t.s_id,
t.s_name,
t.score,
sum(t.score) over(order by t.s_name) sum
from score t;
返回结果:
分析:第二行的sum=第一行里的score+第二行里的score;
第三行的sum=第一行里的score+第二行里的score+第三行里的score;
……
结论:返回值是根据排序后的结果,当前所在的行进行统计的。over(partition by ...)用在聚合函数(max(),sum()....)后面,可根据partition by里制定的某一列来统计聚合值。
Exp:
Sql‘代码
select t.class_id,
t.s_id,
t.s_name,
t.score,
sum(t.score) over(partition by t.class_id) sum
from score t;
返回的结果:
分析:每个sum的值都是把class_id相同的score值进行求和。
结论,根据partition by里指定的某一列来统计聚合值。
三、例子
问:按班级“连续”求总和
答:
Sql代码
select t.class_id,
t.s_name,
t.score,
sum(t.score) over(partition by t.class_id order by t.s_name) sum
from score t;
返回的结果:
分析:先根据partition by进行分组,然后再根据order by进行排序“连续”统计(相当于按班级进行累计值)
大家也可以造些部门、员工、工资的数据来体验一下,或者结合项目里的数据,试一下去统计,例如销售的,不同地区不同业务员的销售记录等等,大家都可以试一下
除了sum还可以max、min、avg等等
---sum(a) over()
---sum(a) over(order by ...)
---sum(a) over(partition by...)
---sum(a) over(partition by... order by ...)
---max(a) over()
---max(a) over(order by...)
---max(a) over(partition by...)
---max(a) over(partition by... order by ...)
---min(a) over()
---min (a) over(order by...)
---min (a) over(partition by...)
---min (a) over(partition by... order by ...)
---avg(a) over()
--- avg (a) over(order by...)
--- avg (a) over(partition by...)
--- avg (a) over(partition by... order by ...)
补充:
建表:
-- Create table
create table EMP
(
DEP_NO VARCHAR2(255),
EMP_NO VARCHAR2(255),
NAME VARCHAR2(255),
SAL NUMBER(22,5)
)
tablespace TEST
pctfree 10
initrans 1
maxtrans 255
storage
(
initial 16
minextents 1
maxextents unlimited
);
-- Add comments to the columns
comment on column EMP.DEP_NO
is '部门编号';
comment on column EMP.EMP_NO
is '员工编号';
comment on column EMP.NAME
is '员工姓名';
comment on column EMP.SAL
is '工资';
插入数据:
DEP_NOEMP_NONAMESAL
1101001张三4578.11000
2101002李四11455.47000
3101003王五15987.32000
4202001赵六8913.29000
5202002唐铭4977.19000
6202003宋清14932.81000
7303001元凯6837.28000
8303002陈冬7691.56000
9303003林梅5678.12000
--查询各部门中的最低工资通常写法
select dep_no, min(sal) min, max(sal) max from emp group by dep_no;
查询结果:
--假如想要把本部门所有员工的工资,与本部门的最低,最高工资对比时显然上述查询是做不到的,则我们可以用以下语句:
select dep_no,
name,
sal,
avg(sal) over(partition by dep_no) avg,
min(sal) over(partition by dep_no) min,
max(sal) over(partition by dep_no) max
from emp
group by dep_no, name, sal;
查询结果:
--用于查找记录的上一条,及下一条,以作为对比:
select name,
sal,
lead(sal, 1, null) over(partition by dep_no order by sal) next_sal,
lag(sal, 1, null) over(partition by dep_no order by sal) up_sal
from emp;
注:lead函数是先按dep_no分组,按sal排序,并把当前行sal的下一个值放到next_sal中,比如:
sal=4578.11000的下一个值是11455.47000,sal=11455.47000 的下一个值是15987.32000。
函数中的null是当没有下一个值时用null代替,当然也可以用其他值替换NULL.
lag与lead相反,是取上一个值的意思
查询结果:
当然也可以不要partition,lag的默认参数是1
select name,
sal,
lead(sal, 1, null) over(order by sal) next_sal,
lag(sal, 1, null) over(order by sal) up_sal
by max over partition_Oracle分析函数小结(over()、over(order by ...)、over(partition by...))...相关推荐
- by max over partition_Oracle高级查询之over(partition by...)
为了方便学习和测试,所有的例子都是在Oracle自带用户Scott下建立的. create table EMP ( empno NUMBER(4) not null, ename VARC ...
- Oracle分析函数巧妙使用
在 Oracle中使用Sql必须弄懂分析函数 Oracle开发专题之:分析函数(OVER) 1 Oracle开发专题之:分析函数2(Rank, Dense_rank, row_number) 6 Or ...
- Hive窗口函数小结
文章目录 一.窗口函数作用 1.1.测试数据 1.2.应用场景 二.窗口函数概念 2.1.语法结构 2.2.分析函数 2.3.over函数的参数 三.窗口函数入门 3.1.over(partition ...
- Oracle -- 分析函数
MySQL中的derived table(r12... ORACLE利用STANDBY端RMAN备份... Oracle并行计算 Oracle 12CR2 dbca -silent -... MySQ ...
- 利用分析函数和开窗函数进行分组查询
分析函数之分组排序 1.分析函数释义 row_number() OVER ( PARTITION BY COL1 ORDER BY COL2) 表示根据COL1分组,在分组内部根据 COL2排 ...
- oracle 数据分析函数,ORACLE分析函数(一)
ORACLE分析函数(1) 分析函数式ORACLE提供的用来进行数据统计的强有力工具,与我们常用的聚合函数具有一些相似性,但又完全不同.聚合函数,首先会将数据进行分组,然后对每一组数据进行运算,如求和 ...
- oracle之分析函数over及开窗函数
2019独角兽企业重金招聘Python工程师标准>>> 一:分析函数overOracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是对于 ...
- 【学习笔记】分析函数(开窗函数)
分析函数 这里的分析函数也就是我们常说的开窗函数,通常有两类: 一类是聚合开窗函数(SUM.AVG.MAX.MIN.COUNT等), 一类是排序开窗函数(ROW_NUMBER.DENSE_RANK.R ...
- Hive 窗口分析函数
1.窗口函数 1.LAG(col,n,DEFAULT) 用于统计窗口内往上第n行值 第一个参数为列名,第二个参数为往上第n行(可选,默认为1),第三个参数为默认值(当往上第n行为NULL时候,取默认值 ...
最新文章
- 关于git bush 中不能复制黏贴的问题
- EOS 智能合约源代码解读 (10)token合约“简介”
- 枚举类的使用-使用实例域来替代序数
- 适合小白的卷积神经网络图解
- ++递归 字符串全排列_超全递归技巧整理,这次一起拿下递归
- 从 JavaScript 到 TypeScript
- Python最大公约数gcd、最小公倍数lcm
- Github代码安全监控
- 小爱同学指令大全_小爱同学有趣的命令分享给大家
- Eclipse:更换背景图片
- 电脑无法复制粘贴怎么办的解决方法
- 简洁桌面(使用Windows自带的桌面整理功能)
- 当当网按关键字搜索商品教程
- 游戏账号交易平台,是专门为网络游戏提供相关交易服务的电子商务平台,主要从事网络游戏账号的交易。
- Python格式化新年祝福语
- 5g通用模组是什么_5G通用模组需要做哪些温湿度可靠性测试?
- mac安装Homebrew报443
- 关于安装Python过程中 无法访问Windows Installer服务问题解决
- 编译出现错误,想知道为什么错误
- Win10无法访问网上邻居共享设备及共享文件夹错误代码(0x80004005)
热门文章
- 微信开发者工具打开是黑屏
- zipkin 禁止_Spring Cloud - Zipkin
- zipkin 禁止_MySQL数据库之zipkin使用mysql保存数据
- 股票程序化交易软件好用吗?
- 【Rust日报】2021-02-16 “火旋风”代码分析器
- RTEMS 移植 CS8900网卡成功
- 取消粘滞键_禁用“刺激性粘滞键/过滤器键”弹出对话框
- 核心动画(12)性能调优
- 有什么好用的图片裁剪软件?这几种裁剪方法了解一下
- c++ jna 数据类型_JNA 使用总结