`
ghl116
  • 浏览: 161519 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

oracle top N(转)

阅读更多


1.在ORACLE中实现SELECT TOP N

   由于ORACLE不支持SELECT TOP语句,所以在ORACLE中经常是用ORDER BY跟ROWNUM的组合来实现SELECT TOP N的查询。

简单地说,实现方法如下所示:

      SELECT 列名1...列名n FROM

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

       WHERE ROWNUM <= N(抽出记录数)

      ORDER BY ROWNUM ASC

   下面举个例子简单说明一下。

顾客表customer(id,name)有如下数据:

      ID NAME

       01 first

       02 Second

       03 third

       04 forth

       05 fifth

       06 sixth

       07 seventh

       08 eighth

       09 ninth

       10 tenth

       11 last

   则按NAME的字母顺抽出前三个顾客的SQL语句如下所示:

      SELECT * FROM

        (SELECT * FROM CUSTOMER ORDER BY NAME)

       WHERE ROWNUM <= 3

       ORDER BY ROWNUM ASC

   输出结果为:

      ID NAME

       08 eighth

       05 fifth

       01 first

2.在TOP N纪录中抽出第M(M <= N)条记录

在得到了TOP N的数据之后,为了抽出这N条记录中的第M条记录,我们可以考虑从ROWNUM着手。我们知道,ROWNUM是记录表中数据编号的一个隐藏子段,所以可以在得到TOP N条记录的时候同时抽出记录的ROWNUM,然后再从这N条记录中抽取记录编号为M的记录,即使我们希望得到的结果。

从上面的分析可以很容易得到下面的SQL语句。

      SELECT 列名1...列名n FROM

         (

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

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

         WHERE ROWNUM <= N(抽出记录数)

       ORDER BY ROWNUM ASC

         )

       WHERE RECNO = M(M <= N)

同样以上表的数据为基础,那么得到以NAME的字母顺排序的第二个顾客的信息的SQL语句应该这样写:

       SELECT ID, NAME FROM

         (

          SELECT ROWNUM RECNO, ID, NAME FROM

            (SELECT * FROM CUSTOMER ORDER BY NAME)

             WHERE ROWNUM <= 3

             ORDER BY ROWNUM ASC )

           WHERE RECNO = 2

     结果则为:

       ID NAME

        05 fifth

3.抽出按某种方式排序的记录集中的第N条记录

   在2的说明中,当M = N的时候,即为我们的标题讲的结果。实际上,2的做法在里面N>M的部分的数据是基本上不会用到的,我们仅仅是为了说明方便而采用。

   如上所述,则SQL语句应为:

       SELECT 列名1...列名n FROM

         (

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

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

             WHERE ROWNUM <= N(抽出记录数)

          ORDER BY ROWNUM ASC

         )

         WHERE RECNO = N

     那么,2中的例子的SQL语句则为:

        SELECT ID, NAME FROM

          (

           SELECT ROWNUM RECNO, ID, NAME FROM

             (SELECT * FROM CUSTOMER ORDER BY NAME)

           WHERE ROWNUM <= 2

           ORDER BY ROWNUM ASC

          )

          WHERE RECNO = 2

     结果为:

       ID NAME

        05 fifth

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

       3里所讲得仅仅是抽取一条记录的情况,当我们需要抽取多条记录的时候,此时在2中的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的字母顺的第2条记录开始的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

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

 

分享到:
评论

相关推荐

    如何在Oracle中实现SELECT TOP N的方法

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

    Oracle 的top问题

    oracle数据库中的top n问题,上述文件结合数据库分页说明了oracle中的top n问题

    获取top前10个Oracle的进程(支持多实例)

    A、获取top前10个Oracle的进程,并打印出(根据实际进程情况列出 R/S 状态) B、对这些进行进行PS检查资源占有情况,并确定是那个数据库实例的进程 C、根据当前目录下的connect.json配置数据库连接数据库访问,打印...

    在ORACLE中实现SELECT TOP N的方法

    在ORACLE中实现SELECT TOP N的方法,所讲的都是一些最基本的,实际应用中往往都没有这么简单,但是不管怎么说,不管复杂的应用总是由这些简单的元素构成,掌握一些最基本的方法始终是重要的。

    如何在Oracle中实现SELECT_TOP_N的方法

    如何在Oracle中实现SELECT_TOP_N的方法

    在ORACLE中SELECT TOP N的实现方法

    1.在Oracle中实现SELECT TOP N  由于ORACLE不支持SELECT TOP语句,所以在ORACLE中经常是用ORDER BY跟ROWNUM的组合来实现SELECT TOP N的查询。  简单地说,实现方法如下所示: SELECT 列名1...列名n FROM ...

    oracle select top的方法

    Oracle SQL语法不支持select top 100 * from table_a之类的top语法,当然可以使用rownum取出多少行来看,但是如果加上排序还使用这个rownum的话,大部分情况是,先取出rownum行记录,然后排序再显示,这和我们要求的...

    sql语句中select top n与oracle的rownum与mysql的limit用法

    sql语句中select top n与oracle的rownum与mysql的limit 取前几条数据sql简单用法

    oracle 分析函数详解(有例子)

    3 Oracle开发专题之:分析函数3 Top Bottom N First Last NTile 4 Oracle开发专题之:窗口函数 5 Oracle开发专题之:报表函数 6 Oracle开发专题之:分析函数总结 7 Oracle开发专题之:26个分析函数 8 分析函数...

    Oracle高级sql学习与练习

    8、ROWNUM-TOP-N分析 9、相关子查询和非相关子查询 10、增强GROUP BY 11、分析函数(ANALYTICAL FUNCTIONS) 12、ROWID的使用 13、ORACLE 10G正则表达式 14、使用HINT 15、PARITION分区 16、并行操作 17、扩展DDL和...

    Oracle开发之分析函数(Top/Bottom N、First/Last、NTile)

    本文主要是对Oracle分析函数查找前几名、后几名、最多、最少以及按层次查询的介绍,需要的朋友可以参考下。

    深入浅出Oracle分析函数

    目录 Oracle开发专题之:分析函数(OVER) Oracle开发专题之:分析函数2(Rank, Dense_rank, row_number) Oracle开发专题之:分析函数3(Top/Bottom N、First/Last、NTile) Oracle开发专题之:窗口函数 ...

    Oracle_详解分析函数

    2.Top/Bottom N查询 3.First/Last排名查询 4.按层次查询 1.窗口函数简介 2.窗口函数示例-全统计 3.窗口函数进阶-滚动统计(累积/均值) 4.窗口函数进阶-根据时间范围统计 5.窗口函数进阶-first_value/last_value 6....

    oracle分组排序统计高级用法

    oracle如何实现分组排序和统计、聚集,如何分组求top N,什么是over分析函数,row_number(),rank(),dense_rank()区别又是什么, 如何找到一条记录的前后值,这份文档写得太好了。

    oracle分析函数,窗口函数,报表函数

    oracle分析函数,窗口函数,报表函数 分析函数(OVER) 分析函数2(Rank, Dense_rank, row_number) 分析函数3(Top/Bottom N、First/Last、NTile)

    Expert.Oracle.Indexing.and.Access.Paths

    Database system performance is one of the top concerns in information technology today. Administrators struggle to keep up with the explosion of access and activity driven by the proliferation of ...

    Expert.Oracle.Indexing.and.Access.Paths.2nd.epub

    Database system performance is one of the top concerns in information technology today. Administrators struggle to keep up with the explosion of access and activity driven by the proliferation of ...

    oracle高级函数说明

    包含Oracle常用的高级函数,比如取前N名,每个分组的前N名等。 详细介绍Oracle分析函数(OVER、Rank、Dense_rank、row_number、Top/Bottom N、First/Last、NTile) ,窗口函数,报表函数

Global site tag (gtag.js) - Google Analytics