查询Oracle分组查询,最大值的记录

查询Oracle分组查询,最大值的记录,第1张

这个题目真虎人,我还专门建了个表给你做的:

select from test a where aupdatetime=(select max(bupdatetime) from test b where atype=btype)

呵呵 你试一下吧。

用row_number() over ()按那个字段从大到小进行编号,然后取编号值小于等于10的记录。

仅仅用order by和rownum结合的方式好像结果不正确,需要都嵌套了查询。

下面是关于rownum的介绍

================================

Rownum和row_number() over()的使用

ROWNUM是Oracle从8开始提供的一个伪列,是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出

比如SELECT FROM torderdetail a

WHERE ROWNUM <= 10

这条语句就是输出前10条纪录,在这里用途上类似于sql sever的top,不过rownum对于指定编号区间的输出应该说更强大SELECT FROM (SELECT a, ROWNUM rn

FROM torderdetail a)

WHERE rn >= 10 AND rn <= 20

这条语句即是输出第10到第20条纪录,这里之所以用rownum rn,是把rownum转成实例,因为rownum本身只能用 <=的比较方式,只有转成实列,这样就可做 >=的比较了。

在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum <=一般常见的SELECT FROM (SELECT a

FROM torderdetail a

ORDER BY order_date DESC)

WHERE ROWNUM <= 10

而在CSDN曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句SELECT a

FROM torderdetail a

WHERE ROWNUM <= 10

ORDER BY order_date DESC

之所以会出现这样的语句,主要是从效率上的考虑,前面条语句,是要进行全表扫描后再排序,然后再取10条纪录,后一条语句则不会全表扫描,只会取出10条纪录,很明显后条语句的效率会高许多。

那为什么会有争议呢,那就在于在执行顺序上争议,是先执行排序取10条纪录,还是取10条纪录,再排序呢?两种顺序取出来的结果是截然相反的,先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的最早的10条纪录。对于此语句,普遍的认为执行顺序是先取10条纪录再排序的。所以此语句应该是错误。但实际上并非如此,此语句的执行顺序和order by的字段有关系,如果你order by 的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是PK 时,是先取10条再排序,此时结果就与要求不一样了,所以第二种写法一定要在排序字段是主键的情况下才能保证结果正确。

Row_number() over()这个分析函数是从9I开始提供的,一般的用途和rownum差不多。

一般写法row_number() over( order by order_date desc) 生成的顺序和rownum的语句一样,效率也一样(对于同样有order by 的rownum语句来说),所以在这种情况下两种用法是一样的。

而对于分组后取最近的10条纪录,则是rownum无法实现的,这时只有row_number可以实现,row_number() over(partition by 分组字段 order by 排序字段)就能实现分组后编号,比如说要取近一个月的每天最后10个订单纪录SELECT FROM (SELECT a,

ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC)rnFROM torderdetail a)

select a员工编号,a员工姓名,a类别,a分公司,c薪酬合计

from 表名 a

inner join

(

select 员工编号,最大月份=max(月份)

from 表名

group by 员工编号

) b

on a员工编号=b员工编号 and a月份=b最大月份

inner join

(

select 员工编号,薪酬合计=sum(薪酬)

from 表名

group by 员工编号

) c

on a员工编号=c员工编号

用rownum效率更高,下面是语句不一定正确,你试着改下,希望能帮到你

select tcard_id,tupload_time from CHRDATAUPLOAD t where

trownum = (select max(rownum) from CHRDATAUPLOAD t1 where t1card_id = tcard_id )

以上就是关于查询Oracle分组查询,最大值的记录全部的内容,包括:查询Oracle分组查询,最大值的记录、oracle中如何用sql实现查出某一张表中,某个字段的值最大的10条记录、在Oracle怎样查询表中的top10条记录等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9626152.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-30
下一篇 2023-04-30

发表评论

登录后才能评论

评论列表(0条)

保存