科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道在Oracle中实现SELECT TOP N的方法(3)

在Oracle中实现SELECT TOP N的方法(3)

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文通过举例的方式来教你如何在Oracle中实现SELECT TOP N的方法。

作者:feihu1984 来源:赛迪网 2007年9月3日

关键字: 数据库 ORACLE SELECT TOP N

  • 评论
  • 分享微博
  • 分享邮件

结果为:

ID NAME

05 fifth

4.抽出按某种方式排序的记录集中的第M条记录开始的X条记录:

上一点所讲的仅仅是抽取一条记录的情况,当我们需要抽取多条记录的时候,此时在第二点中的N的取值应该是在N >= (M + X - 1)这个范围内,当然最经济的取值就是取等号的时候了。当然最后的抽取条件也不是RECNO = N了,应该是RECNO BETWEEN M AND (M + X - 1)了,所以随之而来的SQL语句则为:

SELECT 列名1...列名n FROM 

( 

 SELECT ROWNUM RECNO, 列名1...列名nFROM 

(

SELECT 列名1...列名n FROM 表名 ORDER BY 列名1...列名n) 

WHERE ROWNUM <= N (N >= (M + X - 1)) 

ORDER BY ROWNUM ASC 

) 

 WHERE RECNO BETWEEN M AND (M + X - 1)

同样以上面的数据为例,则抽取NAME的字母顺的第二条记录开始的3条记录的SQL语句为:

SELECT ID, NAME FROM 

 ( 

SELECT ROWNUM RECNO, ID, NAME FROM 

(SELECT * FROM CUSTOMER ORDER BY NAME) 

WHERE ROWNUM <= (2 + 3 - 1) 

ORDER BY ROWNUM ASC 

 ) 

 WHERE RECNO BETWEEN 2 AND (2 + 3 - 1)

结果如下:

ID NAME

05 fifth

01 first

04 forth

以此为基础,再扩展的话,做成存储过程,将开始记录数以及抽取记录数为参数,就可以轻松实现分页抽取数据。

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章