【Oracle】分析函数first、last、first_value、last_value

 FIRSTLAST函数

功能:获取首行和尾行(可以有并列的情况)的非排序字段的值

语法:

aggregate_function KEEP (DENSE_RANK {FIRST |LAST }ORDERBY expr [DESC | ASC] [NULLSFIRST | LAST])

OVER (query_partition_clause)

使用说明:

firstlast函数有over子句就是分析函数,没有就是聚合函数。

函数的参数必须是数字类型(或者其他类型可转为数字类型),返回相同类型

aggregate_function可以是MIN,MAX,SUM,AVG,COUNT,VARIANCE,STDDEV

示例:

用表:SELECT *FROM hr.employees;

当作聚合函数用:按部门分组,按提成比例排序,取最大最小薪水

SELECT department_id

      ,MIN(salary)keep(dense_rankFIRST ORDER BY commission_pct) "Worst"

      ,MAX(salary)keep(dense_rankLAST ORDER BY commission_pct) "Best"

  FROM hr.employees

 GROUP BY department_id

 ORDER BY department_id;

当作分析函数用:按部门分组,按提成比例排序,取最大最小薪水

SELECT last_name

     ,department_id

      ,salary

      ,MIN(salary)keep(dense_rankFIRSTORDER BY commission_pct)over(PARTITION BY department_id)"Worst"

      ,MAX(salary)keep(dense_rankLASTORDER BY commission_pct)over(PARTITION BY department_id)"Best"

  FROM hr.employees

 ORDER BY department_id,salary, last_name;

 

first_value()last_value()函数

功能:FIRST_VALUE是一个返回一组排序值后的第一个值的分析函数。

语法:

【推荐】FIRST_VALUE( expr ) [RESPECT |IGNOREN ULLSOVER ( analytic_clause )

【老版本】FIRST_VALUE( expr [RESPECT |IGNOREN ULLS])OVER ( analytic_clause )

使用说明:

在计算时,默认考虑null,除非指定忽略null值。

示例:

60部门按照薪资排序,取第一行、当前行、最后一行

SELECT department_id

     ,employee_id

     ,last_name

      ,salary

     ,first_value(last_name) over(ORDER BY salary rows unbounded preceding)AS fv

     ,last_value(last_name) over(ORDER BY salary ROWS BETWEEN unbounded PRECEDING AND CURRENTROW ) AS lv

     ,last_value(last_name) over(ORDER BY salary ROWS BETWEEN unbounded PRECEDING AND UNBOUNDED FOLLOWING ) AS lv

  FROM hr.employees

 WHERE department_id =60;



  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle分析函数——函数列表 SUM :该函数计算组中表达式的累积和 MIN :在一个组中的数据窗口中查找表达式的最小值 MAX :在一个组中的数据窗口中查找表达式的最大值 AVG :用于计算一个组和数据窗口内表达式的平均值。 COUNT :对一组内发生的事情进行累积计数 ------------------------------------------------------------------------------------------------- RANK :根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置 DENSE_RANK :根据ORDER BY子句中表达式的值,从查询返回的每一行,计算它们与其它行的相对位置 FIRST :从DENSE_RANK返回的集合中取出排在最前面的一个值的行 LAST :从DENSE_RANK返回的集合中取出排在最后面的一个值的行 FIRST_VALUE :返回组中数据窗口的第一个值 LAST_VALUE :返回组中数据窗口的最后一个值。 LAG :可以访问结果集中的其它行而不用进行自连接 LEAD :LEAD与LAG相反,LEAD可以访问组中当前行之后的行 ROW_NUMBER :返回有序组中一行的偏移量,从而可用于按特定标准排序的行号 ------------------------------------------------------------------------------------------------- STDDEV :计算当前行关于组的标准偏离 STDDEV_POP:该函数计算总体标准偏离,并返回总体变量的平方根 STDDEV_SAMP:该函数计算累积样本标准偏离,并返回总体变量的平方根 VAR_POP :该函数返回非空集合的总体变量(忽略null) VAR_SAMP :该函数返回非空集合的样本变量(忽略null) VARIANCE :如果表达式中行数为1,则返回0,如果表达式中行数大于1,则返回VAR_SAMP COVAR_POP :返回一对表达式的总体协方差 COVAR_SAMP :返回一对表达式的样本协方差 CORR :返回一对表达式的相关系数 ------------------------------------------------------------------------------------------------- CUME_DIST :计算一行在组中的相对位置 NTILE :将一个组分为"表达式"的散列表示 PERCENT_RANK :和CUME_DIST(累积分配)函数类似 PERCENTILE_DISC :返回一个与输入的分布百分比值相对应的数据值 PERCENTILE_CONT :返回一个与输入的分布百分比值相对应的数据值 RATIO_TO_REPORT :该函数计算expression/(sum(expression))的值,它给出相对于总数的百分比 REGR_ (Linear Regression) Functions :这些线性回归函数适合最小二乘法回归线,有9个不同的回归函数可使用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值