oracle 分组first,Oracle分析函数:First

本文详细解释了 SQL 中 FIRST_VALUE 函数的用法及其与 DISTINCT 关键字配合使用的区别。通过示例说明如何获取分组中的首个记录,并对比了使用 DISTINCT 和 ROWNUM=1 的性能差异。

楼上例子很经典,但补充两点: 1. 使用DISTINCT与不使用DISTINCT,对FIRST_VALUE函数是有区别的,使用DISTINCT的FIRST_VALUE函数效果等类似于SQL Server中的first(),取得所有分组中的第一条数据。 如果不使用DISTINCT,FIRST_VALUE函数的执行结果,按照楼上

楼上例子很经典,但补充两点:

1. 使用DISTINCT与不使用DISTINCT,对FIRST_VALUE函数是有区别的,使用DISTINCT的FIRST_VALUE函数效果等类似于SQL Server中的first(),取得所有分组中的第一条数据。

如果不使用DISTINCT,FIRST_VALUE函数的执行结果,按照楼上的例子,按照POS分组,对于每个NAME,都返回本组的第一个值(first_value)

SELECT DISTINCT

FIRST_VALUE(NAME) OVER

(PARTITION BY POS ORDER BY AGE DESC)

AS MAXAGE_NAME

,FIRST_VALUE(NAME) OVER

(PARTITION BY POS ORDER BY AGE ASC)

AS MINAGE_NAME

,AVG(AGE) OVER

(PARTITION BY POS)

AS AVG_AGE

,POS

FROM EMP

ORDER BY POS

运行结果

MAXAGE_NAME MINAGE_NAME AVG_AGE POS

1 E C33.6666666666667 PL

2 E C33.6666666666667 PL

3 E C33.6666666666667 PL

4 A B 22.5 PM

5 A B 22.5 PM

2.性能,

通常使用DISTINCT都会造成SQL在运行上性能的损失,但具体损失多少,一般大家没有直观的感受,

根据使用工具Toad(Tools of Oracle Application Developers)的分析结果,相同的SQL使用DISTINCT与使用ROWNUM = 1两种写法, DISTINCT在性能上的损失高达30%以上,证据会在下面给出。

DISTINCT的写法

SELECT DISTINCT

FIRST_VALUE(NAME) OVER

(PARTITION BY ID ORDER BY AGE DESC)

AS MAXAGE_NAME

FROM EMP

ORDER BY POS

ROWNUM = 1的写法

SELECT MAXAGE_NAME

(SELECT

FIRST_VALUE(NAME) OVER

(PARTITION BY ID ORDER BY AGE DESC)

AS MAXAGE_NAME

FROM EMP

ORDER BY POS) T

WHERE ROWNUM = 1 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值