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

Oracle分页,Oracle中rownum与rowid的理解

 
阅读更多

一、         oracle rownumrowid的理解

rownum,rowid都叫伪列。 但是,rownum是逻辑上的编号,且其值总是从1开始,每行的rounum不是固定的。而rowid物理编号。若数据库文件没有移动,则每行的 rowid一般是固定不变的。

 

raclerownum用法的总结

对于 Oracle rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<<=!=),并非说用>,>=,=,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这些条件,因为从缓冲区或数据文件中得到的第一条记录的rownum1,则被删除,接着取下条,可是它的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后的记录的 rownum10,因条件为 !=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 rnt1.* from a where ...)

where rn >10

 

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

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

另外还要注意:rownum不能以任何基表的名称作为前缀。

二、         Oracle分页查询

/*从第1条开始,每次选N个,从第1+M个开始每次选N*/

/**/

select t2.*

   from (select rid

           from (select r.rid, rownum linenum

                   from (select rowid rid

                           from tablename t [条件限制]

                          [order by rid desc]) r

                  WHERE rownum <= 5 [条件限制]

                  [order by rid desc]))

WHERE linenum >= 1) t1, tablename t2

where t1.rid = t2.rowid

/*排序,选出来5个,分页显示,下面两为两种方法*/

select t2.*

   from (select rid

           from (select r.rid, rownum linenum, r.*

                   from (select rowid rid, t.* from tablename t) r

                  WHERE rownum <= 10 [条件限制]

                  [order by rowid desc])

          WHERE linenum >= 6) t1,

        tablename t2

where t1.rid = t2.rowid

   select *

     from (select t.*, rownum rn

             from tablename t

            where rownum <= 10 [条件限制]

            [order by t.rowid desc])

    where rn >= 6;

 

select * from tablename where rownum>1

select * from tablename where rownum>=1

select * from tablename where rownum>0

select   t2.*
from (select rid

          from (select r.rid, rownum linenum
                  from (select                   
                         rowid rid

                          from tablename t
                         [
条件限制]) r
                 WHERE rownum <= 50)
         WHERE linenum >=1) t1,
       tablename t2
where t1.rid = t2.rowid
(利用rowid分页,效率最高的一种,t2.*根据需要换成需要查询的列)

分享到:
评论

相关推荐

    在oracle中灵活使用Rownum和rowId

    ### 在Oracle中灵活使用Rownum和RowId 在Oracle数据库中,`ROWNUM` 和 `ROWID` 是两个非常重要的概念,它们可以帮助我们在查询数据时实现更灵活的数据管理。本文将详细介绍这两个概念的区别及其使用方法,并通过...

    oracle_SQL中rowid与rownum的使用

    三、ROWID与ROWNUM的联合使用 虽然`ROWID`和`ROWNUM`都与表行相关,但它们的作用不同,有时可以结合起来使用。例如,当我们需要根据行号获取特定行的数据,而又不希望影响其他查询时,可以先使用`ROWNUM`筛选出行号...

    oracle的分页查询

    本文将讲解 Oracle 中的分页查询,包括使用 ROWNUM 伪列和 ORDER BY 子句对查询结果进行排序和分页。 一、使用 ROWNUM 伪列实现分页查询 在 Oracle 中,ROWNUP 伪列是一个特殊的列,可以用来实现分页查询。例如,...

    Oracle查询语句中rownum与rowid的不同之处分析

    Oracle数据库中,rownum和rowid是两个非常重要的概念,它们在查询语句中有着不同的作用和特性。本文将深入探讨两者的区别,并通过实例解析它们在查询中的行为。 首先,rownum是一个“伪数列”,它并不是数据库中...

    oracle分页程序的实现

    在Oracle数据库中,常见的分页查询方法有ROWNUM和ROW_NUMBER()函数,以及使用子查询和连接操作来实现分页。 1. ROWNUM方法: ROWNUM是Oracle中的内置伪列,它会为每一行数据生成一个唯一的数字,从1开始递增。但...

    oracle_SQL-rowid--rownum.zip_oracle

    同时,从提供的压缩文件名来看,除了`oracle_SQL中rowid与rownum的使用.doc`直接相关外,其他文件如`ssi2配置整合步骤.doc`、`Spring事物配置.doc`、`Struts2防止表单重复提交.doc`、`SSH改造DAO.doc`涉及的是其他...

    对于 Oracle 的 rownum 问题

    =),并非说用&gt;,&gt;=,=,between..and 时会提示SQL语法错误,而是经常是查不出一条记录来,还会出现似乎是莫名其妙的结果来,其实您只要理解好了这个 rownum 伪列的意义就不应该感到惊奇,同样是伪列,rownum 与 rowid ...

    myeclise+oracle分页

    【标题】"myeclipse+oracle分页"涉及的关键知识点主要集中在两个方面:MyEclipse集成开发环境和Oracle数据库的分页查询技术。下面将详细阐述这两个方面的内容。 首先,MyEclipse是一款强大的Java集成开发环境(IDE...

    oracle rownum 学习

    Oracle中的ROWNUM是在取数据的时候产生的序号,所以想对指定排序的数据去指定的ROWNUM行数据就必须注意了。例如: ```sql SELECT ROWNUM, ID, NAME FROM STUDENT ORDER BY NAME; ``` 可以看出,ROWNUM并不是按照NAME...

    oracle的伪列与分页

    #### 二、ROWID与ROWNUM详解 **ROWID:** - **定义**:ROWID是Oracle中用于唯一标识表中每一行记录的一个伪列。 - **特性**: - 每个表的每一行都有一个唯一的ROWID值。 - ROWID包含行的实际物理地址。 - 使用...

    rowid与rownumber

    rowid 和 rownum 是 Oracle 数据库中的两个重要概念,对于数据库开发人员来说非常重要。下面我们将详细介绍 rowid 和 rownum 的概念、结构、应用场景等。 一、rowid 概念 rowid 是 Oracle 数据库中的一个虚列,...

    oracle分页查询

    首先,我们要理解Oracle分页查询的基本概念。分页查询允许我们按照指定的页码和每页大小来获取数据,这样用户可以逐步浏览数据,而不是一次性看到所有内容。在Oracle中,这通常涉及到对数据进行排序和分配行号。 ...

    Oracle分页技术

    总之,Oracle分页技术是数据库管理中的重要工具,它结合了ROWNUM、嵌套查询和优化策略来有效地处理大数据量的查询。理解这些概念和技巧对于编写高效的分页查询至关重要,特别是在处理用户交互式应用时,能够提供快速...

    对Oracle数据库三种分页方法的测试与研究.pdf

    ROWID是Oracle中的另一个伪列,但与ROWNUM不同,ROWID是物理行标识,它标识了数据在表空间中的具体位置。ROWID可以用于快速定位和访问数据,但在分页查询中直接使用ROWID可能会受到表重构或数据移动的影响,因为...

    oracle数据库伪列简单介绍

    ### Oracle数据库伪列简析:rownum与rowid的区别 在Oracle数据库中,存在一种特殊的数据类型被称为“伪列”,这些伪列虽然看起来像是表中的列,但实际上它们并不存储任何数据,而是由数据库动态生成的。本文将重点...

    Oracle中实现MySql中limit+SqlServer分页+分页的存储过程

    本篇文章将探讨如何在Oracle数据库中实现类似MySQL的`LIMIT`分页功能,以及如何模拟SQL Server的分页方式,并介绍`INTERSECT`和`MINUS`这两个SQL运算符。 首先,`INTERSECT`运算符用于找出两个或多个查询结果中的...

    基于Oracle RowID实现批量数据的分页下载.pdf

    总的来说,基于Oracle RowID的分页下载策略结合了`ROWNUM`、`StopKey`、逆向索引和多线程技术,旨在提供一种高效、稳定的方法来处理大规模数据的分批下载需求。这种策略不仅可以减轻数据库服务器的压力,还能确保...

    ORACLE数据库中ROWNUM用法详解

    6. **ROWID与ROWNUM的区别**:ROWID是Oracle数据库中另一个伪列,它标识表中每行的物理位置,是表空间中记录的唯一标识。ROWID是物理存在的,不会因查询顺序改变而变化,可以作为查询条件,不会出现ROWNUM那样的问题...

    java笔记\Oracle里sql不能用limit的处理

    在Oracle中,我们可以使用RowNum函数来实现分页查询。RowNum函数可以返回当前记录的行号,从1开始。我们可以使用RowNum函数来限制查询的记录数。 例如,以下SQL语句可以查询表t_table_name的前10条记录: ```sql ...

    17.Oracle伪列1

    通过创建触发器,将rowid与SQL操作类型一起记录到日志表中,以便追踪数据的变化。 - 作为WHERE条件:由于rowid直接指向数据的物理位置,因此在WHERE子句中使用rowid进行查询具有极高的效率,优于使用索引。 二、...

Global site tag (gtag.js) - Google Analytics