在ORACLE中SELECT 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的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • 在oracle 数据库查询的select 查询字段中关联其他表的方法

    大部分情况下,这种动态生成的sql查询语句写法如下: 复制代码 代码如下: select A表.字段1,A表.字段2,B表.字段返回,C表.字段返回 from A表 ,B表,C表 [where A表,B表,C表关联及各自的条件语句] 但是这个方法有一个缺点,那就是在动态的生成这个查询语句的业务逻辑程序仍然很复杂.这里就介绍一个降低业务逻辑复杂度的查询sql生成方式.其语法结构如下: 复制代码 代码如下: select A表.字段1,A表.字段2,B表.字段,C表.字段 from A表 [wher

  • 最简单的Oracle数据恢复 select as of使用方法

    You perform a Flashback Query by using a SELECT statementwith an AS OF clause.You use a flashback query to restrieve data as it existed at some time in the past.The query explicitly references a past time by menasof timestamp or SCN.It returns commit

  • oracle select执行顺序的详解

    SQL Select语句完整的执行顺序:1.from子句组装来自不同数据源的数据:2.where子句基于指定的条件对记录行进行筛选:3.group by子句将数据划分为多个分组:4.使用聚集函数进行计算:5.使用having子句筛选分组:6.计算所有的表达式:7.使用order by对结果集进行排序. oracle 语句提高查询效率的方法 1:.. where column in(select * from ... where ...); 2:... where exists (select '

  • 解析oracle对select加锁的方法以及锁的查询

    解析oracle对select加锁的方法以及锁的查询一.oracle对select加锁方法 复制代码 代码如下: create table test(a number,b number);insert into test values(1,2);insert into test values(3,4);insert into test values(8,9);commit;---session 1 模拟选中一个号码SQL> select * from test where a =1 for up

  • 在ORACLE中SELECT 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 下面举个例子简单说明一下. 顾客表cu

  • oracle中通配符和运算符的使用方法介绍

    用于where比较条件的有: 等于:=.<.<=.>.>=.<> 包含:in.not in exists.not exists 范围:between...and.not between....and 匹配测试:like.not like Null测试:is null.is not null 布尔链接:and.or.not 通配符: 在where子句中,通配符可与like条件一起使用.在Oracle中: %(百分号): 用来表示任意数量的字符,或者可能根本没有字符. _(

  • oracle中添加删除主键的方法

    1.创建表的同时创建主键约束 (1)无命名 create table student ( studentid int primary key not null, studentname varchar(8), age int); (2)有命名 create table students ( studentid int , studentname varchar(8), age int, constraint yy primary key(studentid)); 2.删除表中已有的主键约束 (1

  • iview中Select 选择器多选校验方法

    iview提供的select组件中使用multiple属性可以开启多选模式,返回的数据也是数组的形式. iview使用的校验是根据async-validator来实现数据验证.验证规则可前去查看开源项目 多选模式下的select组件校验使用type为array,可设置len属性来规定数组的长度,设置len:1则不是数组长度为1则通过校验,不设置则数组有元素则通过校验. { type: 'array', required: true, message: '不能为空'} 正则可以写在data中 在r

  • 在layui中select更改后生效的方法

    在layui中重新渲染表单这一步比较重要,部分表单元素需要重新渲染后才能生效,例如select 建议在js中放入以下function: //重新渲染表单 function renderForm(){ layui.use('form', function(){ var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功 form.render(); }); } 在每次操作部分表单元素后都进行一次调用 以上这篇在layui中select更改后生效的方法就是小编分

  • asp中 select top 问题!~

    sql="select top 8 * from Musiclist where "& sql2 &"  order by hits desc" 选择前八条无效!~  显示出来的是所有新闻!~为什么? 改为下面的就可以 sql="select top 8 * from Musiclist where "& sql2 &"  order by hits,ID desc" 注意id是自动增加的

  • oracle中去掉回车换行空格的方法详解

    去除换行update zhzl_address t set t.add_administration_num=replace(t.add_administration_num,chr(10),'');去掉回车update zhzl_address t set t.add_administration_num=replace(t.add_administration_num,chr(13),'');去掉空格update zhzl_address t set t.add_administration

  • Oracle中插入特殊字符:&和'的解决方法汇总

    今天在导入一批数据到Oracle时,碰到了这样一个问题:Toad提示要给一个自定义变量AMP赋值,一开始我很纳闷,数据是一系列的Insert语句,怎么会有自定义变量呢?后来搜索了一下关键字AMP发现,原来是因为在插入数据中有一个字段的内容如下: http://xxx.com/3DX?uid=0676&sid=rt_060908 Oracle把这里的URL的参数连接符&当成是一个自定义变量了,所以要求我给变量AMP赋值.经过测试之后,总结出以下三种方法: 方法一:在要插入的SQL语句前加上S

  • Oracle中定义以及使用同义词的方法

    前言 在Oracle中对用户的管理是使用权限的方式来管理的,也就是说,如果我们想使用数据库,我们就必须得有权限,但是如果是别人将权限授予了我们,我们也是能对数据库进行操作的,但是我们必须要已授权的表的名称前键入该表所有者的名称,所以这就是比较麻烦的,遇到这种情况,我们该怎么办呢?创建个Oracle同义词吧!这样我们就可以直接使用同义词来使用表了. 下面话不多说了,来一起看看详细的介绍吧 Oracle 同义词概念: Oracle的同义词(synonyms)从字面上理解就是别名的意思,和视图的功能类

  • 解析Oracle中多表级联删除的方法

    表间的关系比较复杂,数据量又比较多,一个个删绝对会出大问题.于是实验了几种解决的办法,现小结一下. 方法一:创建约束时设定级联删除(但一般由于各种原因或出于各种考虑在创建数据库时没有设定级联删除)SQL语句: 复制代码 代码如下: CREATE TABLE "U_WEN_BOOK"."FARTAB" ("FAR_ID" NUMBER(10) NOT NULL,"FAR_NAME" VARCHAR2(10), "OTH

随机推荐