当前位置: 网学 > 编程文档 > ORACLE > 正文

oracle中实现top N

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 12/10/19
下载{$ArticleTitle}原创论文样式

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)

        &nbs

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号