分析函数之keep函数

本文介绍了Oracle数据库中KEEP函数的应用场景及语法,通过实例演示如何在分组查询中选取特定条件下的最大或最小值,对比了KEEP函数与其他分析函数的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、keep函数介绍
-- keep是Oracle下的另一个分析函数,他的用法不同于通过over关键字指定的分析函数,可以用于这样一种场合下:
-- 取同一个分组下以某个字段排序后,对指定字段取最小或最大的那个值。
-- 从这个前提出发,我们可以看到其实这个目标通过一般的row_number分析函数也可以实现,即指定rn=1。但是,
-- 该函数无法实现同时获取最大和最小值。或者说用first_value和last_value,结合row_number实现,
-- 但是该种方式需要多次使用分析函数,而且还需要套一层SQL。于是出现了keep。

-- 语法:
-- min | max(column1) keep (dense_rank first | last order by column2) over (partion by column3);

-- 最前是聚合函数,可以是min、max、avg、sum。。。
-- column1为要计算的列;
-- dense_rank first,dense_rank last为keep 函数的保留属性,表示分组、排序结果集中第一个、最后一个;
-- 解释:返回按照column3分组后,按照column2排序的结果集中第一个或最后一个最小值或最大值column1。

select deptno,
       max(sal) keep(dense_rank first order by sal) first_max,
       max(sal) keep(dense_rank last order by sal) last_max
  from emp
 group by deptno;
-- 我们来分析一下,SQL里面的group by 是作用于聚会函数的,可以这么理解一下。还有,这里我们头脑里应该有这么一个概念,排序即分组。

原文链接https://lanjingling.github.io/2015/10/09/oracle-fenxihanshu-3/

转载于:https://www.cnblogs.com/ls11736/p/9285049.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值