Oracle中查询前10条记录----Top的变相⽤法
在Oracle怎样查询表中的top10条记录呢?
  select * from test where rownum <=10    ----说明: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) rn FROM torderdetail a)
  WHERE rn <= 10
  Rownum的另类⽤法,有时候我们会遇到这种需求,要求输出当⽉的所有天数,许多⼈会烦恼,数据库⾥⼜没有这样的表,怎么输出⼀个⽉的所有天数呢?⽤rownum就能解决:
  SELECT TRUNC (SYSDATE, 'MM') + ROWNUM - 1 FROM DUAL
  CONNECT BY ROWNUM <= TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), 'dd'))
=====================================================================================
Oracle 中的Top写法
由于Oracle不⽀持select top 语句,所以在Oracle中经常是⽤order by 跟rownum
的组合来实现select top n的查询。
简单地说,实现⽅法如下所⽰:
select 列名1 …列名n from
(
select 列名1 …列名n
from 表名 order by 列名1
)
where rownum <=N(抽出记录数)
order by rownum asc
如:select id,name from (select id,name from student order by name) where rownum<=10 order by rownum asc
按姓名排序取出前⼗条数据
附:⽐如取100-150条数据的⽅法:
(1)最佳选择:利⽤分析函数
row_number() over ( partition by col1 order by col2 )
⽐如想取出100-150条记录,按照tname排序
select tname,tabtype from (
select tname,tabtype,row_number() over ( order by tname ) rn from tab ) where rn between 100 and 150;
(2)使⽤rownum 虚列
select tname,tabtype from (
select tname,tabtype,rownum rn from tab where rownum <= 150
oracle中trunc函数用法
) where rn >= 100;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。