ORACLE 中ROWNUM用法总结!
对于 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这些条件,因为从缓冲区或数据文件中得到的第一条记录的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不能以任何基表的名称作为前缀。

转载于:https://blog.51cto.com/77857/151904

ORACLE 中ROWNUM用法总结!相关推荐

  1. Oracle中rownum用法警示

    今天调试代码,发现分页查询时使用Oracle中rownum的between......and用法的bug,特此总结: 参考资料:http://blog.csdn.net/lg312200538/art ...

  2. 转:ORACLE 中ROWNUM用法总结!

    对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(<.<=.!=),并非说用>,>=,=,be ...

  3. ORACLE 中ROWNUM用法总结(转载)

    原文出處:http://www.cnblogs.com/believe3301/archive/2007/10/10/919408.html 对于 Oracle 的 rownum 问题,很多资料都说不 ...

  4. oracle rownum=1什么意思,Oracle中rownum用法总结

    对于Oracle的rownum问题,很多资料都说不支持>,>=,=,between--and,只能用以上符号(,>=,=,between--and 时会提示SQL语法错误,而是经常是 ...

  5. 你听过Oracle中rownum用法吗?

    1. 概述 rownum是Oracle引入的虚列.  在物理上这个虚列并不存在,只是在查询时才构造出来.伪列通常是自由分配的,用户无法执行修改等操作. 2. 特点 关于rownum有以下主要特点: r ...

  6. Oracle数据库之rownum,ORACLE数据库中Rownum用法详解

    ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(,& gt;=,=, ...

  7. oracle rownum_,oracle中rownum和row_number()

    row_number()over(partition by col1 order by col2)表示根据col1分组,在分组内部根据col2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内 ...

  8. Oracle中rownum的说明及用法总结

    Oracle中rownum的说明及用法总结 一.rownum的说明 rownum是Oracle特有的一个关键字. (1)对于基表,在insert记录时,oracle就按照insert的顺序,将rown ...

  9. oracle中 rownum与rowid的理

    一. Oracle分页查询 我们先看学习一下oracle分页查询的语法示例,然后在具体学习用rownum的原理. /*从第1条开始,每次选N个,从第1+M个开始每次选N个*/ /**/ select  ...

最新文章

  1. Mac 安装多个版本jdk
  2. 一个简单的动态内表alv案例
  3. mysql时间格式函数_MySQL时间格式函数
  4. 硬核 | 亚洲诚信@FreeBuf企业安全俱乐部,实力诠释“S/MIME可信企业安全邮件解决方案”...
  5. mosquitto查看订阅记录_Mosquitto\Client
  6. Hibernate中saveOrUpdate()和merge()的区别
  7. 吴恩达神经网络和深度学习-学习笔记-8-梯度消失与爆炸 + 梯度检测
  8. 作战军事环境仿真系统软件解决方案
  9. 光盘出租系统mysql_数据库课程设计--碟片出租系统
  10. 酒店管理系统需求分析
  11. Word文档中统一字符串八大妙法(转)
  12. Java格式化百分比
  13. oracle lob类型 删除,oracle中lob类型介绍
  14. win10安装消息队列服务器,win10下celery搭建使用
  15. 匈牙利法及其最优性分析
  16. 部署 PXE 远程安装与无人值守安装服务
  17. 5000立方米球罐设计
  18. 婚礼请柬邀请函电子版制作模板,520一起来参加婚礼吧!
  19. 工科生安装Ubuntu18.04后干的事情
  20. 魔兽世界服务端centos架设

热门文章

  1. 工作站的windows server 2008 终于安装好了
  2. Oracle 日常开发记录
  3. Shell调试Debug的三种方式
  4. Kibana_X-Pack管理Elasticsearch权限
  5. mfc读取bmp文件_LIUNX 工程bmp.c 显示图片 开发板出来的图片只有一个角 求大佬解决...
  6. IDEA for win 常用快捷键
  7. python传递变量_在Python中传递变量
  8. ubuntu安装 rust nightly_一起学Rust编程「1」:开发环境
  9. python提供两种基本循环结构_零基础学python 12 程序不枯燥:for循环结构(课后习题)...
  10. Python使用ldap3操作微软AD