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

概念及特性

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…

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值