怎样提取oracle数据库中前N个数据

怎样提取oracle数据库中前N个数据,第1张

oracle中取前N个数据,可用rownum实现。

如emp表中有如下数据:

现在要求取出前5条数据,可用如下语句

select * from emp where rownum<=5

执行结果:

由于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


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

原文地址: http://outofmemory.cn/sjk/10825511.html

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

发表评论

登录后才能评论

评论列表(0条)

保存