Oracle 分析函数over,列转行函数pivot理解及综合运用(报表中的小计和合计)

article/2025/9/17 10:48:44

1、Over函数(分析统计函数)

1.1语法

sum/avg/count() over(partition by ..)
  • over()在什么条件之上;
  • partition by 按哪个字段划分组;

1.2示例

SELECT E.ENAME,E.JOB,E.SAL,E.DEPTNO,SUM(E.SAL) OVER(PARTITION BY E.DEPTNO) SUM_SAL,     --统计某组中的总计值AVG(E.SAL) OVER(PARTITION BY E.DEPTNO) AVG_SAL,     --统计某组中的平均值COUNT(E.SAL) OVER(PARTITION BY E.DEPTNO) COUNT_SAL  --按某列分组,并统计该组中记录数量FROM EMP E;

在这里插入图片描述

2、Pivot函数(行转列函数)

2.1语法
Pivot函数是将多行聚合并转置为列,每列代表不同范围的聚合数据。新语法的概述如下:

SELECT ...
FROM   ...
PIVOT [XML]( pivot_clausepivot_for_clausepivot_in_clause )
WHERE  ...
  • pivot_clause:定义要聚合的列(pivot 是聚合操作);
  • pivot_for_clause:定义要分组和旋转的列;
  • pivot_in_clause:为 pivot_for_clause中的列定义过滤器(即限制结果的值范围)。pivot_in_clause
    中每个值的聚合将被转置到单独的列中(在适当的情况下)

2.2例子
以Emp表为例,按部门和工作对薪水求和,但将每个部门的总和转移到自己的列中。在我们调整工资之前,我们将检查基础数据,如下所示:

SQL> SELECT job2  ,      deptno3  ,      SUM(sal) AS sum_sal4  FROM   emp5  GROUP  BY6         job7  ,      deptno8  ORDER  BY9         job10  ,      deptno;JOB           DEPTNO    SUM_SAL
--------- ---------- ----------
ANALYST           20       6600
CLERK             10       1430
CLERK             20       2090
CLERK             30       1045
MANAGER           10       2695
MANAGER           20     3272.5
MANAGER           30       3135
PRESIDENT         10       5500
SALESMAN          30       61609 rows selected.

对于每个职位,我们把部门进行行转列,让所有部门变成了列,显示工资总额,这样的数据相比较上面的数据更加简洁直观,如下所示:

SQL> WITH pivot_data AS (2          SELECT deptno, job, sal3          FROM   emp4          )5  SELECT *6  FROM   pivot_data7  PIVOT (8             SUM(sal)        --<-- pivot_clause9         FOR deptno          --<-- pivot_for_clause10         IN  (10,20,30,40)   --<-- pivot_in_clause11        );JOB               10         20         30         40
--------- ---------- ---------- ---------- ----------
CLERK           1430       2090       1045
SALESMAN                              6160
PRESIDENT       5500
MANAGER         2695     3272.5       3135
ANALYST                    66005 rows selected.

3、综合运用

说明:根据列的特定值条件,统计符合条件数量.

3.1报表需求(如下):

在这里插入图片描述

3.2原始数据(如下):

select csm.short_name 经销商简称,csm.code 经销商编码,asa.product_time 生产日期, --生产日期adp.pickup_date 提货日期, --提货日期aso.orders_type, --订单类型 0:正单,1:改补单aso.order_number 订单号, --订单数apdi.tag_number 包号, --包数apdi.quantity 件数 --件数from aba --批次表inner join asa --班次表on asa.is_phantom = '0'and asa.id = aba.shifts_audit_idinner join apmi --装箱单信息on apmi.batch_audit_id = aba.idand apmi.is_phantom = '0'inner join  apdi --装箱单明细on apdi.is_phantom = '0'and apdi.package_main_info_id = apmi.idinner join aso --销售订单on aso.is_phantom = '0'and aso.id = apmi.sales_order_idinner join  adp --提货计划on adp.is_phantom = '0'and adp.sale_order_id = aso.idinner join csmon csm.id = aso.dealer_idand csm.is_phantom = '0'where asa.product_time >= to_date('2022-03-01', 'yyyy-mm-dd')AND asa.product_time <= to_date('2022-03-02', 'yyyy-mm-dd')

在这里插入图片描述

3.3综合运用(最终效果):

分析:根据上述报表和原始数据我们可以知道,一个订单包含了很多个包,每一行数据就是一包,我们需要按生产日期统计订单数,包数,件数,但是其中又根据订单类型进一步拆分了正单和改补单,因此我们可以把订单类型也加入到分组列当中,作为行转列的一个数据源列。


select 经销商简称,经销商编码,生产日期,提货日期,包数,nvl(正单_订单数,0),nvl(正单_板件数,0),sum(正单_订单数) over (partition by 生产日期) 正单_订单小计,sum(正单_板件数) over (partition by 生产日期) 正单_板件小计,nvl(改补_订单数,0),nvl(改补_板件数,0),sum(改补_订单数) over (partition by 生产日期) 改补_订单小计,sum(改补_板件数) over (partition by 生产日期) 改补_板件小计,sum(nvl(正单_订单数,0) + nvl(改补_订单数,0)) over (partition by 生产日期) 订单合计,sum(nvl(正单_板件数,0)+ nvl(改补_板件数,0)) over (partition by 生产日期) 板件合计from (select csm.short_name 经销商简称,csm.code 经销商编码,asa.product_time 生产日期, --生产日期adp.pickup_date 提货日期, --提货日期decode(aso.orders_type, 0, 0, 1) orderType, --订单类型0:正单,1:改补单count(distinct aso.order_number) orders, --订单数count(distinct apdi.tag_number) 包数, --包数sum(apdi.quantity) qty --件数from aba --批次表inner join asa --班次表on asa.is_phantom = '0'and asa.id = aba.shifts_audit_idinner join apmi --装箱单信息on apmi.batch_audit_id = aba.idand apmi.is_phantom = '0'inner join apdi --装箱单明细on apdi.is_phantom = '0'and apdi.package_main_info_id = apmi.idinner join aso --销售订单on aso.is_phantom = '0'and aso.id = apmi.sales_order_idinner join adp --提货计划on adp.is_phantom = '0'and adp.sale_order_id = aso.idinner join csm_dealer csmon csm.id = aso.dealer_idand csm.is_phantom = '0'where asa.product_time >= to_date('2022-03-01', 'yyyy-mm-dd')AND asa.product_time <= to_date('2022-03-02', 'yyyy-mm-dd')group by csm.short_name,csm.code,asa.product_time, --生产日期adp.pickup_date, --提货日期aso.orders_type)
pivot(sum(orders) as 订单数, sum(qty) 板件数FOR orderType IN(0 AS 正单, 1 AS 改补))

在这里插入图片描述


http://chatgpt.dhexx.cn/article/jgcoKfTa.shtml

相关文章

oracle 百分位数,oracle分析函数 percent_rank, percentile_cont, percentile_disc

)*20=18 percentile_disc() PERCENTILE_DISC 这里就不做详细分析。 Syntax Purpose PERCENTILE_DISC is an inverse distribution function that assumes a discrete distribution model. It takes a percentile value and a sort specification and returns an element from t…

Oracle所有分析函数

Oracle分析函数 Oracle分析函数——函数列表 SUM &#xff1a;该函数计算组中表达式的累积和 MIN &#xff1a;在一个组中的数据窗口中查找表达式的最小值 MAX &#xff1a;在一个组中的数据窗口中查找表达式的最大值 AVG &#xff1a;用于计算…

oracle分析函数over(Partition by...)及开窗函数详解

说明&#xff1a;聚合函数&#xff08;如sum()、max()等&#xff09;可以计算基于组的某种聚合值&#xff0c;但是聚合函数对于某个组只能返回一行记录。若想对于某组返回多行记录&#xff0c;则需要使用分析函数。 1、rank()/dense_rank over(partition by ... order by ...) …

【Oracle】Oracle分析函数详解

Oracle数据库中的函数有多种&#xff0c;比如单行函数、聚合函数、对象引用函数、模型函数、OLAP函数等。本篇将详细介绍Oracle数据库中的分析函数。 一 分析函数概述 所谓分析函数&#xff0c;是基于一组数据行计算聚合值&#xff0c;其与聚合函数的不同之处在于&#xff0c…

oracle分析函数详解

一、Oracle分析函数 分析函数是什么&#xff1f; 分析函数是Oracle专门用于解决复杂报表统计需求的功能强大的函数&#xff0c;它可以在数据中进行分组然后计算基于组的某种统计值&#xff0c;并且每一组的每一行都可以返回一个统计值。 分析函数和聚合函数的不同之处是什么…

Oracle 分析函数练习实例

创建表 create table emp(deptno varchar2(20) ,empno varchar2(20),ename varchar(20),sal number );sql演示 –显示各部门员工的工资&#xff0c;并附带显示该部分的最高工资。 select e.deptno,e.empno,e.ename,e.sal,last_value(e.sal)over(partition by e.deptnoorder …

oracle ntile函数,Oracle分析函数ntile

Oracle分析函数ntile 有这么一个需求&#xff0c;将课程的成绩分成四个等级&#xff0c;为学生打A、B、C、D的绩效。 drop table course purge; create table course ( id number, grade number ); insert into course values(1,50); insert into course values(2,55); insert …

Oracle之分析函数

目录 1. 认识分析函数 1.1 什么是分析函数 1.2 分析函数和聚合函数的不同 1.3 分析函数的形式 2. 理解over()函数 2.1 两个order by 的执行机制 2.2 分析函数中的分组、排序、窗口 2.3 帮助理解over()的实例 3. 常见分析函数 3.1 演示表和数据的生成 3.2 first_valu…

Oracle中的分析函数

目录 1、理解什么是分析函数&#xff1f; 2、分析函数和聚合函数区别&#xff1f; 3、分析函数的语法&#xff1a; 4、常用的分析函数&#xff1a; 5、运用分析函数求相关累计问题 6、运用分析函数求相关排序问题 1. RANK()函数&#xff1a; 2. DENSE_RANK()函数&#…

常用Oracle分析函数大全

Oracle的分析函数功能非常强大&#xff0c;工作这些年来经常用到。这次将平时经常使用到的分析函数整理出来&#xff0c;以备日后查看。 我们拿案例来学习&#xff0c;这样理解起来更容易一些。 1、建表 1 2 3 4 5 6 7 8 9 10 create table earnings -- 打工赚钱表 ( ear…

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

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

Python 输出小数点后保留两位有效数字简便方法

用round(a,n) a代表变量&#xff0c;n代表想保留的小数点的个数&#xff1b;比如&#xff1a;

金额千位分隔符及保留2位小数

目录 numberObject.toFixed(num) 正则 $1、$2 正则 {} 正则 ? 正则 ?&#xff1a; 正则 正则 $ 正则 | numberObject.toFixed(num) NumberObject.toFixed(num) 方法把 Number 四舍五入为指定小数位数数字&#xff0c;返回 string 类型num 规定小数位数 0 ~ 20 之间…

chatgpt赋能python:Python中保留两位小数输出的方法:一个完整的指南

Python中保留两位小数输出的方法: 一个完整的指南 介绍 在Python编程中&#xff0c;有时候我们需要将数字保留到小数点后两位输出。例如&#xff0c;货币单位到分、科学计算等等。本文将介绍多种方法实现这个目标&#xff0c;包括Python的内置函数以及第三方库的函数。 方法…

c++ 保留2位小数输出

1.需要头文件<iomanip> 2.结果会经过四舍五入&#xff1b; 3.公式为 cout<<fixed<<setprecision(2)<<“要输出的变量”<<endl; !!!!!!setprecision()&#xff0c;括号中填几&#xff0c;就是保留几位小数&#xff1b;

python保留2位小数

一&#xff1a;使用占位符方法&#xff1a; # 1&#xff1a;%g 科学计数法输出小数&#xff0c;用于舍弃无效的小数 print("%g"%(1.2000004)) print("%.2g"%(1.2000004)) # 2&#xff1a;直接使用%f 输出小数&#xff0c;会出现无效的0&#xff1b;使用%.…

C语言-------如何打印保留小数点后1,2,..位

首先你要想有小数&#xff0c;则在数据存储时就要用到浮点型&#xff08;float &#xff0c;double&#xff09; float a 0; double a 0; 其次在打印时和输入时都要用对应的%f&#xff08;float&#xff09;,%lf (double) printf("%.2f",) , printf("%.2lf…

【postgresql 小数点】pg保留2位小数

实现方式&#xff1a; cast函数 cast A as B round(cast( A as B),2) SELECT calculate_time,round(CAST("value" as numeric),2) as fcao from arithmetic.dws_tag_today where byt_namehk_fcao and calculate_time > now() - interval 2 hour ORDER BY calcu…

Excel常见函数用法大全+函数宝典.xls

函数宝典下载地址: 百度网盘 EXACT 作用:使用EXACT函数比较两个字符串是否相同 用法: EXACT(A2,B2) 返回值: true和false LEN 作用: 使用LEN函数计算文本中的字符个数 用法: "还可以输入"&(60-LEN(A2)&"个字符") &符号合并的意思 T 作…