简单记录一下oracle 分析函数的使用,随用随更新。
1)max(xx) over(partition by xx) /min(xx) over (partition by xx)
scott/tiger连接:
SQL>SELECT emp.*, max(sal) over(partition by deptno) maxsal FROM EMP;
说明:检索员工所在部门的最高工资。
SQL> SELECT emp.*, max(sal) over(partition by deptno) maxsal FROM EMP;
EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO MAXSAL
----- ---------- --------- ----- ----------- --------- --------- ------ ----------
7782 CLARK MANAGER 7839 1981-6-9 2450.00 10 5000
7839 KING PRESIDENT 1981-11-17 5000.00 10 5000
7934 MILLER CLERK 7782 1982-1-23 1300.00 10 5000
7566 JONES MANAGER 7839 1981-4-2 2975.00 20 3000
7902 FORD ANALYST 7566 1981-12-3 3000.00 20 3000
7876 ADAMS CLERK 7788 1987-5-23 1100.00 20 3000
7369 SMITH CLERK 7902 1980-12-17 800.00 20 3000
7788 SCOTT ANALYST 7566 1987-4-19 3000.00 20 3000
7521 WARD SALESMAN 7698 1981-2-22 1250.00 500.00 30 2850
7844 TURNER SALESMAN 7698 1981-9-8 1500.00 0.00 30 2850
7499 ALLEN SALESMAN 7698 1981-2-20 1600.00 300.00 30 2850
7900 JAMES CLERK 7698 1981-12-3 950.00 30 2850
7698 BLAKE MANAGER 7839 1981-5-1 2850.00 30 2850
7654 MARTIN SALESMAN 7698 1981-9-28 1250.00 1400.00 30 2850
14 rows selected
2)PERCENTILE_CONT(n) WITHIN GROUP (ORDER BY SAL DESC ) 此函数为聚合函数。
例如:PERCENTILE_CONT(0.5) WITHIN GROUP (ORDER BY SAL DESC )
0.5表示取中间数,测试观察便知,n的取值范围0-1。
SQL>SELECT deptno, PERCENTILE_CONT(0) WITHIN GROUP( ORDER BY SAL DESC) ME
2 FROM EMP
3 group by deptno;
DEPTNO ME
---- ----------
10 5000
20 3000
30 2850
说明:按部门分组,检索该部门工资最高的记录,由于此函数为聚合函数,所以和第一个介绍的分析函数还有些区别。测试查询便知。
3)PERCENTILE_CONT(n) WITHIN GROUP( ORDER BY xx DESC) OVER(PARTITION BY XX)
例如:PERCENTILE_CONT(0) WITHIN GROUP( ORDER BY SAL DESC) over(partition by deptno) 非聚合函数
SQL>SELECT emp.*, PERCENTILE_CONT(0) WITHIN GROUP( ORDER BY SAL DESC) over(partition by deptno) ME FROM EMP;
SQL> SELECT emp.*, PERCENTILE_CONT(0) WITHIN GROUP( ORDER BY SAL DESC) over(partition by deptno) ME FROM EMP;
测试结果图如下:
4)PERCENT_RANK() OVER([partition_clause] order_by_clause)
例如:PERCENT_RANK() OVER(partition by deptno order by sal desc)
5)NTILE(n) OVER([partition_clause] order_by_clause)
举例:NTILE(5) OVER(order by sal desc)
说明:按照你指定的组数(n)对记录做分组
注意:如果不能按照你指定的分组数平均分配记录数,则最后的组数的记录数将和之前的不一样多。
分享到:
相关推荐
### Oracle分析函数详解 #### 一、概述 Oracle分析函数是一种强大的工具,它允许用户对分组数据执行复杂的计算,并且结果可以根据特定条件进行动态调整。这种灵活性使得Oracle分析函数在处理复杂的数据集时非常...
Oracle分析函数是数据库管理系统Oracle中的一个强大特性,它允许用户在SQL查询中执行复杂的分析操作。分析函数在处理报表和数据迁移任务时尤其有用,因为它们可以基于分组计算聚合值,并为每个分组返回多行,而不...
Oracle 分析函数(用法+实例) Oracle 分析函数是 Oracle 8.1.6 版本中引入的高级应用,属于 Oracle 的一大亮点。分析函数可以分为四大类:排名函数、聚合函数、行比较函数和统计函数。下面将对分析函数的原理、...
Oracle 分析函数是一种强大的SQL工具,它允许你在处理数据时执行复杂的分析操作,而不像聚合...参考书籍如Tom Kyte的《Expert One-on-One》和Oracle 9i SQL Reference等,都是深入学习和理解Oracle分析函数的宝贵资源。
Oracle 分析函数详解 Oracle 分析函数是 Oracle 数据库中的一种强大功能,能够帮助用户快速进行数据分析和处理。在本文中,我们将对 Oracle 分析函数进行详细的介绍,并对其各个函数进行解释。 一、总体介绍 ...
Oracle 分析函数是一种高级SQL功能,它允许在单个查询中对数据集进行复杂的分析,无需额外的编程或多次数据库交互。分析函数处理的结果通常基于数据的分组、排序或特定窗口,为统计汇总和复杂的数据分析提供了便利。...
Oracle分析函数是数据库管理系统Oracle中的一种高级SQL特性,它允许用户在单个查询中对一组行进行计算,而无需使用子查询或自连接。这些函数极大地增强了数据分析和报告的能力,提高了查询性能。以下是对Oracle分析...
oracle 分析函数 开发必备 数据库开发工程师
Oracle分析函数是数据库管理系统Oracle中的一种高级特性,用于处理和分析数据集,提供了一种高效的方式来执行聚合操作,而无需多次查询数据库。分析函数能够直接在单次查询中完成复杂的数据计算,包括排序、分组、...
### Oracle分析函数详解 #### 一、概述 Oracle分析函数是一种强大的工具,它自Oracle 8.1.6版本开始引入,并在后续版本中不断完善和发展。这类函数的主要用途在于能够针对一组数据执行复杂的聚合计算,并且不同于...
Oracle 分析函数是数据库查询中的强大工具,它们允许在单个SQL语句中对结果集进行复杂的计算和分组操作,极大地简化了数据分析的过程。在Oracle 8i版本之后引入,分析函数为处理大量数据提供了高效的方法,避免了...
ORACLE分析函数 ORACLE分析函数是数据库管理系统中的一种功能强大且灵活的分析工具,能够对数据进行复杂的分析和处理。通过使用分析函数,开发者可以更加方便地实现业务逻辑,提高查询效率和数据处理速度。 在本...
### Oracle分析函数详解 #### 一、概述 Oracle分析函数是一种强大的工具,它允许用户对分组数据执行复杂的计算,并且能够返回多个结果行。这与传统的聚合函数(如`SUM`、`COUNT`等)形成鲜明对比,后者通常只针对...
Oracle分析函数是数据库管理系统Oracle中一组强大的工具,用于处理集合数据,特别是在复杂的报表和数据分析场景中。它们允许用户在单个SQL查询中执行聚合操作,同时保持行的原始顺序,这是传统的GROUP BY函数无法...
Oracle分析函数是数据库管理系统Oracle中的一个重要特性,自8.1.6版本开始引入,它们用于执行基于组的聚合计算,并且为每个组返回多行结果,而不仅仅是单行。这使得分析函数在数据分析和报表生成方面非常有用,能够...