概念及特性

rownum是oracle特有的一个关键字
不属于任何一张表,但是任何表在查询时都可以使用它,它是Oracle数据库在我们查询的时候动态给我们添加的一列,它的规律为从1开始,之后查出每一条数据都会自动+1。注(他动态添加的顺序一定是从1开始,然后每多一条记录就+1 1,2,3,4,5…)

实例解析

例1 我们想查表中的第一条数据
select rownum, e.* from emp e where rownum = 1

结果为:

因为我们限制了rownum=1所以只能查询到一条记录,结果给我们想的一样,没有任何问题.行, 咱们来看下一个例题

例2 我们想查表中的第二条数据

肯定会有人这样写SQL, 如果你也是这样想的那就大错特错了,咱们先来看一下结果

select rownum, e.* from emp e where rownum = 2

结果为:

这时我们看到的结果并不是我们想象的那样,这是为什么呢,问题出在哪里呢?

分析问题

之所以出现没有查到记录,问题还是出现在rownum关键字的特性上,咱们再来回顾以下rownum的性质,它是Oracle数据库在我们查询的时候自动为我们查询的结果添加的一列,从1开始,每多一条记录就+1.
Oracle数据库为我们添加这一列我们可以这样理解,查询一条数据只有这条数据将要展示给我们的时候,它才会被动态添加.
我们来看例1 在进行where条件判断rownum=1时(重点:这时rownum只是用来作为条件使用,并没有真正的加入到表中,只有在条件为真的时候即:这条数据将要展示给我们的时候Oracle数据库才会将它加入到这条记录中,如果条件为假就不会加入),因为rownum的特性从1开始,刚上来rownum=1所以符合where条件,所以rownum=1就会把被添加到给条记录上(重点:只有前面的成功添加到那条记录中后,rownum的值才会变为2,否则仍为1)
正是因为这样的特性例2才没有记录,因为rownum一上来等于1,此时不符合条件所以rownum的值一直为1,所以没有一条记录符合条件rownum=2的,才会有照成这样的结果.

解决方案

相信现在有人心里肯定有了自己的想法,行让我们来看一下正确的答案吧

select * from (
select rownum rn, e.* from emp e ) t where rn = 2;

结果为:

解决思路为:我们用一次子查询,子表的作用就是把所有的记录都查出来,这时Oracle数据累已经给每条记录都加入了rownum这一列,见图中RN字段,这时我们就可以放心的来使用rownum这个东东了,因为它此时已经属于子表里面的内容了,再在外表的条件的位置来限定rn = 2;就把我们想要的结果查询出来了。
祝大家学习顺利
最后附上SQL语句各部分的执行优先级
写的顺序:select … from… where… group by… having… order by…
执行顺序:from… where…group by… having… select … order by…

Oracle数据库分页查询关键字rownum理解相关推荐

  1. 使用oracle数据库分页查询语句,各种数据库的分页查询语句

    各种数据库的分页查询语句 1.oracle数据库分页select * from (select a.*,rownum rc from 表名 where rownum=endrow) a where a ...

  2. oracle数据库 —— 分页查询 java代码实现

    分页查询的核心代码(理解这一句话很重要): prep = conn.prepareStatement("select * from (select t2.*,rownum rn from ( ...

  3. oracle数据库分页查询慢,Oracle数据库中分页查询中排序及效率问题

    原始未分页查询Sql代码如下: select ROWNUM rn, t.id ID, o.name YYB,u.name XM, t.MC from tZDYSX t,tuser u,lborgani ...

  4. Oracle数据库分页查询的几种实现方法

    没有Sql Server有top那么好用,但是Oracle含有隐藏的rownum列可以灵活使用,使实现分页效果,pageSize默认10行 方法一: select * from test where ...

  5. oracle数据库分页查询

    oracle分页有通用写法,假设一页6行 select * from (select t.*,rownum from (select * from table1 where 条件 order by c ...

  6. Oracle数据库实现主键自增(利用sequence)和分页查询(利用rownum)

    一.Oracle数据库实现主键自增必须通过sequence来实现 注意:sequence在每次调用nextval就会自增1 create sequence seq_user; --创建一个user表的 ...

  7. oracle数据库如何写翻页_ORACLE数据库分页查询/翻页 最佳实践

    ORACLE数据库分页查询/翻页 最佳实践 一.示例数据: Select Count(*) From dba_objects ; ----------------------------------- ...

  8. Oracle数据库分页总结

    在Oracle数据库中,数据分页功能是必不可少的操作, Oracle数据库分页查询语句有三种写法: --1.根据ROWID 来分 select * from nmb where rowid in( s ...

  9. 不同数据库分页查询的实现

    分页查询是数据库查询中经常用到的一项操作,对查询出来的结果进行分页查询可以方便浏览.那么Oracle.SQL Server.MySQL是如何实现查询的呢?本文我们就来介绍这一部分内容. 1. SQL ...

最新文章

  1. 哈钦森之问:动物的种类为何如此丰富?
  2. Linux安装Oracle 10g
  3. linux应用程序抢占键盘,linux 系统挂起
  4. 关于要不要买apple watch 的思考:节俭是一种习惯
  5. 【若依(ruoyi)】Swagger 上传接口
  6. 改变Android的hello world程序字体颜色和背景颜色
  7. java 变量作用域 c语言_C语言深入理解 - 常量与变量
  8. java数据库实例_选择数据库实例
  9. Python数据结构与算法(二)栈和队列
  10. .NET设计模式(10):装饰模式(Decorator Pattern)
  11. 小蚂蚁学习C语言(27)——C语言中的进制转换
  12. fanq15/FSOD-code 的环境配置及运行
  13. HTML5视频和音频常见的格式,HTML5中视频音频的使用详解
  14. Fatal NI connect error 12170
  15. 微信小程序8-云函数
  16. matlab蜂窝异构网络基站用户矩阵 依照最近距离配对/快速计算两矩阵彼此距离
  17. Android Studio 安装应用失败总结
  18. 德累斯顿工业大学计算机学院,德累斯顿工业大学好不好
  19. 使用Pandas绘制股票均线
  20. 毕业设计 stm32智能运动计步器 - 物联网 嵌入式 单片机

热门文章

  1. 计算机组成原理【1】
  2. 【数据结构】设计循环队列
  3. Openwrt编译:root.squashfs-64k is too big (Max=6488064 , Current=xxxx)
  4. JavaScript代码运行时间计算
  5. 【Swtich大气层】xci文件转换成nsp文件的方式
  6. 实现动态验证element输入框密码框
  7. 服务器怎么看u盘位置,安装服务器如何修改u盘地址
  8. 5.8 快速定位拥有公式、批注、常量等内容的单元格 [原创Excel教程]
  9. MCTK批处理MODIS L2 swath产品
  10. transmac装黑苹果_用u盘安装黑苹果10.12.3