day05_oracle分析函数

create table earnings -- 打工赚钱表

(

earnmonth varchar2(6), -- 打工月份

area varchar2(20), -- 打工地区

sno varchar2(10), -- 打工者编号

sname varchar2(20), -- 打工者姓名

times int, -- 本月打工次数

singleincome number(10,2), -- 每次赚多少钱

personincome number(10,2) -- 当月总收入

);

然后插入实验数据:

insert into earnings values(‘200912‘,‘北平‘,‘511601‘,‘大魁‘,11,30,11*30);

insert into earnings values(‘200912‘,‘北平‘,‘511602‘,‘大凯‘,8,25,8*25);

insert into earnings values(‘200912‘,‘北平‘,‘511603‘,‘小东‘,30,6.25,30*6.25);

insert into earnings values(‘200912‘,‘北平‘,‘511604‘,‘大亮‘,16,8.25,16*8.25);

insert into earnings values(‘200912‘,‘北平‘,‘511605‘,‘贱敬‘,30,11,30*11);

insert into earnings values(‘200912‘,‘金陵‘,‘511301‘,‘小玉‘,15,12.25,15*12.25);

insert into earnings values(‘200912‘,‘金陵‘,‘511302‘,‘小凡‘,27,16.67,27*16.67);

insert into earnings values(‘200912‘,‘金陵‘,‘511303‘,‘小妮‘,7,33.33,7*33.33);

insert into earnings values(‘200912‘,‘金陵‘,‘511304‘,‘小俐‘,0,18,0);

insert into earnings values(‘200912‘,‘金陵‘,‘511305‘,‘雪儿‘,11,9.88,11*9.88);

insert into earnings values(‘201001‘,‘北平‘,‘511601‘,‘大魁‘,0,30,0);

insert into earnings values(‘201001‘,‘北平‘,‘511602‘,‘大凯‘,14,25,14*25);

insert into earnings values(‘201001‘,‘北平‘,‘511603‘,‘小东‘,19,6.25,19*6.25);

insert into earnings values(‘201001‘,‘北平‘,‘511604‘,‘大亮‘,7,8.25,7*8.25);

insert into earnings values(‘201001‘,‘北平‘,‘511605‘,‘贱敬‘,21,11,21*11);

insert into earnings values(‘201001‘,‘金陵‘,‘511301‘,‘小玉‘,6,12.25,6*12.25);

insert into earnings values(‘201001‘,‘金陵‘,‘511302‘,‘小凡‘,17,16.67,17*16.67);

insert into earnings values(‘201001‘,‘金陵‘,‘511303‘,‘小妮‘,27,33.33,27*33.33);

insert into earnings values(‘201001‘,‘金陵‘,‘511304‘,‘小俐‘,16,18,16*18);

insert into earnings values(‘201001‘,‘金陵‘,‘511305‘,‘雪儿‘,11,9.88,11*9.88);

Commit;

然后看看刚刚建好的表:

select * from earnings;

(1)sum函数,统计总合
按照月份,统计每個地区的总收入

select earnmonth, area, sum(personincome)

from earnings

group by earnmonth, area;

查看结果如下:

(2)rollup函数
按照月份,地区统计收入

select earnmonth, area, sum(personincome)

from earnings

group by rollup(earnmonth, area);

查看结果如下:

(3)cube函数
按照月份,地区进行收入总汇总

select earnmonth, area, sum(personincome)

from earnings

group by cube(earnmonth, area)

order by earnmonth, area nulls last;

结果如下:

小结:sum是统计求和的函数。
group by 是分组函数,按照earnmonth和area先后次序分组。
以上三例都是先按照earnmonth分组,在earnmonth内部再按area分组,并在area组内统计personincome总合。
group by 后面什么也不接就是直接分组。
group by 后面接 rollup 是在纯粹的 group by 分组上再加上对earnmonth的汇总统计。
group by 后面接 cube 是对earnmonth汇总统计基础上对area再统计。
另外那个 nulls last 是把空值放在最后。

(4)grouping函数
在以上例子中,是用rollup和cube函数都会对结果集产生null,这时候可用grouping函数来确认
该记录是由哪个字段得出来的
grouping函数用法,带一个参数,参数为字段名,结果是根据该字段得出来的就返回1,反之返回0

Sql代码  

select decode(grouping(earnmonth), 1, ‘所有月份‘, earnmonth) 月份,

decode(grouping(area), 1, ‘全部地区‘, area) 地区,

sum(personincome) 总金额

from earnings

group by cube(earnmonth, area)

order by earnmonth, area nulls last;

查看结果如下:

(5)rank() over开窗函数
按照月份、地区,求打工收入排序

Sql代码  

select earnmonth 月份,

area 地区,

sname 打工者,

personincome 收入,

rank() over(partition by earnmonth, area order by personincome desc) 排名

from earnings;

查看结果:

(6)dense_rank() over开窗函数
按照月份、地区,求打工收入排序2

Sql代码  

select earnmonth 月份,

area 地区,

sname 打工者,

personincome 收入,

dense_rank() over(partition by earnmonth, area order by personincome desc) 排名

from earnings;

结果如下:

(7)row_number() over开窗函数
按照月份、地区,求打工收入排序3

Sql代码  

select earnmonth 月份,

area 地区,

sname 打工者,

personincome 收入,

row_number() over(partition by earnmonth, area order by personincome desc) 排名

from earnings;

结果如下:

通过(5)(6)(7)发现rank,dense_rank,row_number的区别:
结果集中如果出现两个相同的数据,那么rank会进行跳跃式的排名,
比如两个第二,那么没有第三接下来就是第四;
但是dense_rank不会跳跃式的排名,两个第二接下来还是第三;
row_number最牛,即使两个数据相同,排名也不一样。

(8)sum累计求和
根据月份、地区求出各个打工者收入总和,按照收入由少到多排序

Sql代码  

select earnmonth 月份,

area 地区,

sname 打工者,

sum(personincome) over(partition by earnmonth, area order by personincome) 总收入

from earnings;

查看结果如下:

(9)max,min,avg和sum函数综合运用
按照月份和地区求打工收入最高值,最低值,平均值和总额

Sql代码  

select distinct earnmonth 月份,

area 地区,

max(personincome) over(partition by earnmonth, area) 最高值,

min(personincome) over(partition by earnmonth, area) 最低值,

avg(personincome) over(partition by earnmonth, area) 平均值,

sum(personincome) over(partition by earnmonth, area) 总额

from earnings;

结果如下:

(10)lag和lead函数
求出每个打工者上个月和下个月有没有赚钱(personincome大于零即为赚钱)

Sql代码  

select earnmonth 本月,

sname 打工者,

lag(decode(nvl(personincome, 0), 0, ‘没赚‘, ‘赚了‘), 1, 0) over(partition by sname order by earnmonth) 上月,

lead(decode(nvl(personincome, 0), 0, ‘没赚‘, ‘赚了‘), 1, 0) over(partition by sname order by earnmonth) 下月

from earnings;

说明:Lag和Lead函数可以在一次查询中取出某个字段的前N行和后N行的数据

语法如下:

lag(value_expression [,offset] [,default]) over ([query_partition_clase] order_by_clause);
lead(value_expression [,offset] [,default]) over ([query_partition_clase] order_by_clause);
其中:
value_expression:可以是一个字段或一个内建函数。
offset是正整数,默认为1,指往前或往后几点记录.因组内第一个条记录没有之前的行,最后一行没有之后的行,
default就是用于处理这样的信息,默认为空。

再讲讲所谓的开窗函数,开窗函数就是 over([query_partition_clase] order_by_clause)。比如说,我采用sum求和,rank排序等等,但是我根据什么来呢?over提供一个窗口,可以根据什么什么分组,就 用partition by,然后在组内根据什么什么进行内部排序,就用 order by。

来自为知笔记(Wiz)

时间: 2024-10-27 05:22:50

day05_oracle分析函数的相关文章

Oracle分析函数

1. ASCII 返回与指定的字符对应的十进制数; SQL> select ascii(A) A,ascii(a) a,ascii(0) zero,ascii( ) space from dual; A A ZERO SPACE --------- --------- --------- --------- 65 97 48 32 2. CHR 给出整数,返回对应的字符; SQL> select chr(54740) zhao,chr(65) chr65 from dual; ZH C --

学习Oracle分析函数(Analytic Functions)

Oracle提供了一些功能很强大的分析函数,使用这些函数可以完成可能需要存储过程来实现的需求. 分析函数计算基于一组数据行的聚合值,它们不同于聚合函数的是,它们为每一组返回多行结果.分析函数是除ORDER BY子句之外,在查询语句中最后执行的.所有的join和所有的WHERE ,GROUP BY 和HAVING子句都在分析函数之前执行.所以分析函数只能出现在select或ORDER BY子句中. 下图为11.2版本官方文档中给出的语法示意图: 下面简单介绍一下各个部分: analytic_fun

Oracle分析函数参考手册

Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是对于每个组返回多行, 而聚合函数对于每个组只返回一行. 常用的分析函数如下所列: row_number() over(partition by ... order by ...) rank() over(partition by ... order by ...) dense_rank() over(partition by ... order by ...) count() over(part

oracle分析函数(2)

常用分析函数: 1. first,last --假设a := min(奖金) keep(dense_rank first order by 工资) --假设工资最少为1000,a为在工资等于1000的员工取最小的奖金 --假设b := min(奖金) keep(dense_rank last order by 工资) --假设工资最多为9999,b为在工资等于9999的员工取最小的奖金 --作为聚合函数 select e.department_id, min(e.hire_date) keep(

一、Oracle分析函数入门

分析函数是什么?分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数,它可以在数据中进行分组然后计算基于组的某种统计值,并且每一组的每一行都可以返回一个统计值. 分析函数和聚合函数的不同之处是什么?普通的聚合函数用group by分组,每个分组返回一个统计值,而分析函数采用partition by分组,并且每组每行都可以返回一个统计值. 分析函数的形式分析函数带有一个开窗函数over(),包含三个分析子句:分组(partition by), 排序(order by), 窗口(row

oracle 分析函数总结--仅供参考

/*  目录: 1.语法 2.常见函数及用法   2.1 排序函数   2.2 wm_concat()能实现不同行同字段的合并 !!!!生产环境慎用   2.3 开窗用法    2.4 占比函数ratio_to_report( ) over(partition by  )   2.5 前一个lag 后一个 lead   2.6 第一个first_value 最后一个last_value   2.7 加1连乘再减1    */      --1.分析函数的语法 :函数名() over (分区 排序

ORACLE分析函数(1)

1. oracle中日期转换为yyyy年mm月dd日的形式 select to_char(sysdate,'"年"mm"月"dd"日"') from dual; 2. oracle分析函数语法 2.1 ORDER BY select e.last_name, e.manager_id, e.salary, avg(e.salary) over() as emp_count --等同于(select avg(*) from employees) f

分析函数

在OLAP这类系统或者DW这类数据库中,作为某份报表的数据源,我们常常需要在某个存储过程中编写复杂的运算代码来汇总数据.分析函数便具备这样的能力,引用多行的数据值来进行多层面的聚合运算,在数据子集中进行颗粒度级别的排序控制.   分析函数不能嵌套,但是可以通过用视图或者表函数封装然后再套上一层分析函数 语法: function(argument1,argument2,argument3...) over ([partition by] [order by] [windowing-clause])

分析函数— —统计

很多需求中都涉及到统计:均值.累计.范围均值.相邻记录比较等.这些操作会统计多次,或有明确的统计范围,或返回的记录统计的数据集不同... 根据场景不同可分为如下几类:       1. 全统计    2. 滚动统计    3. 范围统计    4. (相邻)行比较 构建测试数据:SQL> desc criss_sales;Name       Type        Nullable Default Comments ---------- ----------- -------- -------