在Oracle怎样查询表中的top10条记录

如题所述

下面是关于rownum的介绍================================Rownum和row_number() over()的使用ROWNUM是Oracle从8开始提供的一个伪列,是把SQL出来的结果进行编号,始终从1开始,常见的用途就是用来分页输出.比如SELECT *FROM torderdetail aWHERE ROWNUM <= 10这条语句就是输出前10条纪录,在这里用途上类似于sql sever的top,不过rownum对于指定编号区间的输出应该说更强大SELECT *FROM (SELECT a.*, ROWNUM rnFROM torderdetail a)WHERE rn >= 10 AND rn <= 20这条语句即是输出第10到第20条纪录,这里之所以用rownum rn,是把rownum转成实例,因为rownum本身只能用 <=的比较方式,只有转成实列,这样就可做 >=的比较了。在实际用途中,常常会要求取最近的几条纪录,这就需要先对纪录进行排序后再取rownum <=一般常见的SELECT *FROM (SELECT a.*FROM torderdetail aORDER BY order_date DESC)WHERE ROWNUM <= 10而在CSDN曾经发生过讨论,关于取近的10条纪录,有人给出这样的语句SELECT a.*FROM torderdetail aWHERE ROWNUM <= 10ORDER 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)
温馨提示:内容为网友见解,仅供参考
第1个回答  2018-04-13

根据时间条件排序,取前十条和后十条。

1、有时间字段, 根据时间条件排序,取前十条和后十条

(1)前十条:

select * from (select * from tab_name a order by date_col )

where rownum<11;

(2)后十条:

select * from (select * from tab_name a order by date_col  desc)

where rownum<11;

2、没有时间字段, 直接根据物理存储顺序,取前十条和后十条

(1)前十条:

select * from (select * from tab_name a order by rownum) 

where rownum<11;

(2)后十条:

select * from (select * from tab_name a order by rownuml  desc) 

where rownum<11;

本回答被网友采纳

在Oracle怎样查询表中的top10条记录
这条语句就是输出前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转成实例,因为ro...

oracle如何查询前十个数据
oracle中前N条数据可用row_number来实现。如表中数据:现在要求按照ID倒序,取出前十位:oracle中执行方法:select t.id,t.name from(select test.*,row_number() over (order by id desc) rn from test) twhere rn<=10;结果:

Oracle查询前几条数据的方法
在Oracle中,当需要查询前几条数据时,通常采用以下步骤:首先,从指定表中选择需要的列,然后对这些列进行排序(如按姓名),接着应用一个子查询,其中包含`rownum`列,`rownum`从1开始递增。在子查询的`where`子句中,设置`rownum`小于或等于所需的记录数,如`where rownum <= N`,最后再按`rownu...

Oracle查询前几条数据的方法
由于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,nam...

如何获取数据前十条?分别用oracle ,sql server,和mysql
sql我就会~select top 10 * from 表 order by 排序字段 asc(升序) \/desc(降序)不用排序的话, select top 10 * from 表 就可以了

请问:oracle数据库,使用sql语句,如何获取数据前十条?
主要就是因为 oracle 中没有 top ,不过ORACLE 中有等价的用法 select ...from (select ... from table1 order by ...)where rownum<n;像你这种情况就是 n=10 记得给分哦,^_^

怎么查询ORACLE表中的最后的10条数据
不太明白LZ的意思,数据库中记录的排列是无序的,用逆排序的方法可以对字段排序。楼上貌似是SQL Server的语法,Oracle可以用子查询。SELECT * FROM (SELECT * FROM TAB ORDER BY TNAME DESC)WHERE ROWNUM <= 10;

如何查询数据库中排名前几位的数据
方法一: select top 10 * from 表名 order by 列名 方法二: select top 10 percent * from 表名 order by 列名 方法一:是按照指定列名排序后,取前十个方法二:按照指定列名排序后,取总数的10% 希望能够满足您的需求,谢谢采纳 ...

Oracle 查询前10%的数据
oracle本身不提供top关键字,如果想要查询前几条,可以使用rownum伪列实现。实现步骤:1、使用count聚合函数统计共有多少条数据 select count(*) from Table1; 2、根据count聚合查询总条数乘以百分比,来确定要查询的条数 select count(*)*0.1 from Table1; 3、查询该表数据,取出伪列小于共...

请问一下oracle中,如何实现查询前几条记录?
可以用rownum来查询 例如:select * from 用户名.表名 where rownum <= 100则查询前100条数据,oracle会根据查询结果筛选前100条,记得如果增加查询条件,oracle首先会根据查询条件进行筛选,然后再取前100条,而不是筛选100条后才根据查询条件进行筛选 ...

相似回答