Oracle分析函数三——SUM,AVG,MIN,MAX,COUNT

简介:
Oracle 分析函数——SUM,AVG,MIN,MAX,COUNT
SUM
功能描述:该函数计算组中表达式的累积和。
SAMPLE :下例计算同一经理下员工的薪水累积值
 
MIN
功能描述:在一个组中的数据窗口中查找表达式的最小值。
SAMPLE :下面例子中 dept_min 返回当前行所在部门的最小薪水值
 
MAX
功能描述:在一个组中的数据窗口中查找表达式的最大值。
SAMPLE :下面例子中 dept_max 返回当前行所在部门的最大薪水值
 
AVG
功能描述:用于计算一个组和数据窗口内表达式的平均值。
SAMPLE :下面的例子中列 c_mavg 计算员工表中每个员工的平均薪水报告
 
SELECT
 department_id,
 first_name||' '||last_name employee_name,
 hire_date, 
 salary,
 MIN(salary) OVER (PARTITION BY department_id order by hire_date) AS dept_min,
 MAX(salary) OVER (PARTITION BY department_id order by hire_date) AS dept_max, 
 AVG(salary) OVER (PARTITION BY department_id order by hire_date) AS dept_avg,   
 SUM(salary) OVER (PARTITION BY department_id order by hire_date) AS dept_sum/*,   
 COUNT(*) OVER (ORDER BY salary) AS count_by_salary, 
 COUNT(*) OVER (ORDER BY salary RANGE BETWEEN 50 PRECEDING AND 150 FOLLOWING) AS count_by_salary_range*/
FROM employees
 
 
COUNT
功能描述:对一组内发生的事情进行累积计数,如果指定 * 或一些非空常数, count 将对所有行计数,如果指定一个表达式, count 返回表达式非空赋值的计数,当有相同值出现时,这些相等的值都会被纳入被计算的值;可以使用 DISTINCT 来记录去掉一组中完全相同的数据后出现的行数。
SAMPLE :下面例子中计算每个员工在按薪水排序中当前行附近薪水在 [n-50,n+150] 之间的行数, n 表示当前行的薪水
例如, Philtanker 的薪水 2200 ,排在他之前的行中薪水大于等于 2200-50 的有 1 行,排在他之后的行中薪水小于等于 2200 + 150 的行没有,所以 count 计数值 cnt3 为 2 (包括自己当前行); cnt2 值相当于小于等于当前行的 SALARY 值的所有行数
 
SELECT
 department_id,
 first_name||' '||last_name employee_name,
 salary,
 COUNT(*) OVER (ORDER BY salary) AS count_by_salary, 
 COUNT(*) OVER (ORDER BY salary RANGE BETWEEN 50 PRECEDING AND 150 FOLLOWING) AS count_by_salary_range
FROM employees
WHERE department_id in (10,20,30);
 





本文转自baoqiangwang51CTO博客,原文链接:http://blog.51cto.com/baoqiangwang/312690 ,如需转载请自行联系原作者
相关文章
|
8天前
|
SQL Oracle 关系型数据库
[Oracle]面试官:你举例几个内置函数,并且说说如何使用内置函数作正则匹配
本文介绍了多种SQL内置函数,包括单行函数、非空判断函数、日期函数和正则表达式相关函数。每种函数都有详细的参数说明和使用示例,帮助读者更好地理解和应用这些函数。文章强调了字符串操作、数值处理、日期计算和正则表达式的使用方法,并提供了丰富的示例代码。作者建议读者通过自测来巩固学习成果。
12 1
[Oracle]面试官:你举例几个内置函数,并且说说如何使用内置函数作正则匹配
|
4月前
|
SQL Oracle 算法
|
2月前
|
Oracle NoSQL 关系型数据库
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
主流数据库对比:MySQL、PostgreSQL、Oracle和Redis的优缺点分析
313 2
|
4月前
|
SQL Oracle 关系型数据库
|
4月前
|
SQL Oracle 关系型数据库
Oracle|内置函数之INSTR
【7月更文挑战第5天】
|
4月前
|
Oracle 关系型数据库 数据挖掘
|
4月前
|
Oracle 关系型数据库 数据挖掘
|
5月前
|
存储 Oracle NoSQL
Oracle中decode函数详解
Oracle中decode函数详解
|
5月前
|
Oracle 关系型数据库 大数据
oracle递归函数
oracle递归函数
|
6月前
|
SQL Oracle 前端开发
Oracle效率分析,Github标星25K+超火的前端实战项目
Oracle效率分析,Github标星25K+超火的前端实战项目