`
TravelAllRound
  • 浏览: 2305 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

对于Oracle的rownum问题

 
阅读更多

对于Oracle的rownum问题,很多资料都说不支持>,>=,=,between……and,只能用以上符号(<、& lt;=、!=),并非说用>,>=,=,between……and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来,其实您只要理解好了这个rownum伪列的意义就不应该感到惊 奇,同样是伪列,rownum与rowid可有些不一样,下面以例子说明:

  假设某个表t1(c1)有20条记录。

  如果用select rownum,c1 from t1 where rownum < 10,只要是用小于号,查出来的结果很容易地与一般理解在概念上能达成一致,应该不会有任何疑问的。

   可如果用select rownum,c1 from t1 where rownum > 10(如果写下这样的查询语句,这时候在您的头脑中应该是想得到表中后面10条记录),你就会发现,显示出来的结果要让您失望了,也许您还会怀疑是不谁删 了一些记录,然后查看记录数,仍然是20条啊?那问题是出在哪呢?

   先好好理解rownum的意义吧。因为ROWNUM是对结果集加的一 个伪列,即先查到结果集之后再加上去的一个列 (强调:先要有结果集)。简单的说rownum是对符合条件结果的序列号。它总是从1开始排起的。所以你选出的结果不可能没有1,而有其他大于1的值。所 以您没办法期望得到下面的结果集:

  11 aaaaaaaa

  12 bbbbbbb

  13 ccccccc……

  rownum >10 没有记录,因为第一条不满足去掉的话,第二条的ROWNUM又成了1,所以永远没有满足条件的记录。或者可以这样理解:

   ROWNUM是一个序列,是oracle数据库从数据文件或缓冲区中读取数据的顺序。它取得第一条记录则rownum值为1,第二条为2,依次类推。如 果你用>,>=,=,between……and这些条件,因为从缓冲区或数据文件中得到的第一条记录的rownum为1,则被删除,接着取下 条,可是它的rownum还是1,又被删除,依次类推,便没有了数据。

  有了以上从不同方面建立起来的对rownum的概念,那我们可以来认识使用 rownum 的几种现像

   1. select rownum,c1 from t1 where rownum != 10 为何是返回前9条数据呢?它与 select rownum,c1 from tablename where rownum < 10 返回的结果集是一样的呢?

   因为是在查 询到结果集后,显示完第 9 条记录后,之后的记录也都是 != 10,或者 >=10,所以只显示前面9条记录。也可以这样理解,rownum 为9后的记录的 rownum为10,因条件为 !=10,所以去掉,其后记录补上,rownum又是10,也去掉,如果下去也就只会显示前面9条记录了

  2. 为什么 rownum >1 时查不到一条记录,而 rownum >0 或 rownum >=1 却总显示所以的记录因为 rownum 是在查询到的结果集后加上去的,它总是从1开始

  3. 为什么 between 1 and 10 或者 between 0 and 10 能查到结果,而用 between 2 and 10 却得不到结果原因同上一样,因为 rownum 总是从 1 开始

  从上可以看出,任何时候想把 rownum = 1 这条记录抛弃是不对的,它在结果集中是不可或缺的,少了rownum=1 就像空中楼阁一般不能存在,所以你的 rownum 条件要包含到 1

  但如果就是想要用 rownum > 10这种条件的话话就要用嵌套语句,把rownum先生成,然后对他进行查询。

  select *

  from (selet rownum as rn,t1.* from a where ……)

  where rn >10

  一般代码中对结果集进行分页就是这么干的。

   另外:rowid与rownum虽都被称为伪列,但它们的存在方式是不一样的,rowid可以说是物理存在的,表示记录在表空间中的唯一位置ID,在 DB中唯一。只要记录没被搬动过,rowid是不变的。rowid相对于表来说又像表中的一般列,所以rowid为条件就不会有 rownum那些情况发生。

rownum和排序:
SQL> select rownum ,id,name from student order by name;
    ROWNUM ID     NAME
---------- ------ ---------------------------------------------------
         3 200003 李三
         2 200002 王二
         1 200001 张一
         4 200004 赵四
可以看出,rownum并不是按照name列来生成的序号。系统是按照记录插入时的顺序给记录排的号,rowid也是顺序分配的。为了解决这个问题,必须使用子查询
SQL> select rownum ,id,name from (select * from student order by name);
    ROWNUM ID     NAME
---------- ------ ---------------------------------------------------
         1 200003 李三
         2 200002 王二
         3 200001 张一
         4 200004 赵四
这样就成了按name排序,并且用rownum标出正确序号(由小到大)

分享到:
评论

相关推荐

    对于 Oracle 的 rownum 问题

    对于 Oracle 的 rownum 问题,很多资料都说不支持&gt;,&gt;=,=,between...and,只能用以上符号(&lt;、、!=),并非说用&gt;,&gt;=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来...

    oracle rownum 的使用 和sqlserver有区别的!

    - 在 Oracle 中,ROWNUM 默认从 1 开始计数,对于每一行返回一个唯一的行号。 - ROWNUM 的值是在数据检索的过程中动态生成的,这意味着它并不依赖于表中的任何字段。 2. **基础查询:** - 直接使用 ROWNUM 进行...

    oracle rownum 学习

    ROWNUM对于`ROWNUM(n&gt;1的自然数)的条件认为是成立的,所以可以找到记录。例如: ```sql SELECT ROWNUM, ID, NAME FROM STUDENT WHERE ROWNUM ; ``` 六、ROWNUM用于查询某区间的数据 查询ROWNUM在某区间的数据,...

    oracle rownum和distinct

    下面我们将详细地解释 ROWNUM 和 DISTINCT 的工作原理,并分析为什么它们在一起使用时会出现一些问题。 首先, lets' talk about ROWNUM。ROWNUM 是 Oracle 系统赋予查询返回的行的编号,它是从 1 开始的,这个伪...

    ORACLE 中ROWNUM用法总结

    在Oracle数据库中,`ROWNUM`是一个非常有用的伪列,用于限制查询结果的行数,尤其是在处理大数据量或进行分页查询时。然而,`ROWNUM`的使用并不直观,尤其是当涉及到比较运算符(如`&gt;`, `&gt;=`, `=`等)时,容易引发...

    ROWNUM的使用技巧

    ROWNUM 是 Oracle 中的一种伪列,它可以根据返回记录生成一个序列化的数字。利用 ROWNUM,我们可以生产一些原先难以实现的结果输出,但是因为它是伪列的特殊性,在使用时需要注意一些事项,以免掉入“陷阱”。 特殊...

    Oracle中rownum的使用

    Oracle中rownum的使用

    Oracle rownum.docx

    其次,对于大于某个值的查询,ROWNUM&gt;2这样的条件同样无效,因为Oracle在处理时会先生成ROWNUM,然后检查条件,当ROWNUM已经生成并小于或等于2时,不会有任何行满足ROWNUM&gt;2的条件。解决这个问题的方法是使用子查询...

    oracle rownum 使用技术.pdf

    然而,在对结果进行排序后使用ROWNUM获取Top N数据时,需要注意一些潜在的问题。这是因为ROWNUM在执行计划的早期阶段就被计算,而ORDER BY子句是在后期阶段才被处理。这意味着即使对数据进行了排序,ROWNUM仍然可能...

    oracle-rownum用法

    ROWNUM 对于 `ROWNUM (n&gt;1 的自然数)的条件认为是成立的,所以可以找到记录。 取指定范围的记录 要查询 ROWNUM 在某区间的数据,必须使用子查询。例如,要查询 ROWNUM 在第二行到第三行之间的数据,包括第二行和...

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

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

    关于oracle的rownum

    Oracle ROWNUM 伪列详解 Oracle 的 ROWNUM 伪列是一个非常重要的概念,它对结果集加的一个伪列,即先查到结果集之后再加上去的一个列。了解 ROWNUM 的意义是非常重要的,否则可能会出现莫名其妙的结果。 ROWNUM ...

    解析oracle的rownum

    显然 ROWNUM 对于 ROWNUM(n&gt;1 的自然数)的条件认为是成立的,所以可以找到记录。 ```sql SQL&gt; select rownum,id,name from student where rownum ; ``` 结果: ``` ROWNUM ID NAME ---------- ------ --------...

    Oracle Rownum的使用与JSP分页显示的实现.pdf

    通过这种方式,JSP结合Oracle的Rownum特性,可以实现高效的分页显示,避免一次性加载大量数据导致的性能问题,同时提升用户体验。值得注意的是,由于Rownum的特性,当使用子查询时,需要确保Rownum的筛选在最外层,...

    oracle的rownum用法

    理解`ROWNUM`的工作原理对于编写高效的Oracle查询至关重要,尤其是在处理大型数据集时,能够帮助我们避免不必要的性能问题。正确使用`ROWNUM`可以让我们更好地控制查询结果的范围,从而实现更精细化的数据处理。

    mysql类似oracle rownum写法实例详解

    在 Oracle 中,`ROWNUM` 是一个非常有用的特性,它可以在查询时为每一行生成一个唯一的序列号,这对于限制返回结果的数量或者进行分页查询非常有用。然而,MySQL 并不直接支持 `ROWNUM` 这一概念。但在实际应用中,...

    oracle中取中间记录的方法

    本文将详细介绍如何利用Oracle中的`MINUS`操作符以及`ROWNUM`伪列来实现这一功能。 #### ROWNUM伪列简介 在介绍具体方法之前,我们首先了解一下`ROWNUM`伪列的基本概念。`ROWNUM`是Oracle提供的一种特殊的伪列,它...

    oracle中rownum的用法及解说

    ### Oracle中的ROWNUM使用详解 在Oracle数据库中,`ROWNUM`是一个非常有用的伪列,它可以帮助用户在查询结果集中为每一行分配一个唯一的行号。`ROWNUM`的值从1开始,并随着行的增加而递增。下面将详细介绍`ROWNUM`...

    ORACLE数据库中ROWNUM用法详解

    理解ROWNUM的这些特性对于编写高效的Oracle SQL查询至关重要,特别是当需要处理大量数据并进行分页展示时。正确使用ROWNUM可以提高查询效率,避免不必要的性能问题。通过深入理解ROWNUM的工作原理,开发者能够更好地...

    oracle中rownum的用法

    `ROWNUM`对于数据检索、分页查询以及对特定行进行操作等方面极为有用。接下来,我们将详细介绍`ROWNUM`的各种用法。 #### 二、ROWNUM的基本用法 ##### 1. 获取单行数据 当您希望仅获取表中的某一行数据时,可以...

Global site tag (gtag.js) - Google Analytics