下面是关于rownum的介绍
================================
rownum和row_number()
over()的使用
比如select
*from
torderdetail
a
where
rownum
=
这条语句就是输出前10条纪录,今天这一节用途上类似于sql
sever的top,不过rownum对于指定编号区间的输出应该说更强大select
(select
a.*,
rn
from
a)
and
rn,是把rownum转成实例,因为rownum本身只能用
=的比较方式,只有转成实列,这样就可做
=的比较了.
在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum
=一般常见的select
a.*
order
by
order_date
desc)
而在csdn曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句select
desc
之所以会出现这样的语句,主要是从效率上的考虑,前面条语句,是要进行全表扫描后再排序,然后再取10条纪录,后一条语句则不会全表扫描,只会取出10条纪录,很明显后条语句的效率会高许多.
那为什么会有争议呢,那就在于在执行顺序上争议,是先执行排序取10条纪录,还是取10条纪录,再排序呢?两种顺序取出来的结果是截然相反的,先排序再取10条,就是取最近的10条,而先取10条,再排序,则取出的最早的10条纪录.对于此语句,普遍的认为执行顺序是先取10条纪录再排序的.所以此语句应该是错误.但实际上并非如此,此语句的执行顺序和order
by的字段有关系,如果你order
的字段是pk,则是先排序,再取10条(速度比第一种语句快),而排序字段不是pk
时,是先取10条再排序,此时结果就与要求不一样了,所以第二种写法一定要在排序字段是主键的情况下才能保证结果正确.
row_number()
一般写法row_number()
over(
生成的顺序和rownum的语句一样,效率也一样(对于同样有order
的rownum语句来说),所以在这种情况下两种用法是一样的.
oracle中前N条数据可用row_number来实现.
如表中数据:
现在要求按照ID倒序,取出前十位:
oracle中执行方法:
select?t.id,t.name?from
(select?test.*,row_number()?over?(order?by?id?desc)?rn?from?test)?t
where?rn=10;
结果:
以上就是土嘎嘎小编为大家整理的oracle怎么查看前十条记录相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!