Oracle 分页

1.ROWNUM:
概念:OORACLE使用ROWNUM是一个伪列,数据库提取记录才会生成的数值1,2,3,4 作用是用于实现ORACLE的分页必须使用子查 询实现

执行流程(带条件) :  a.查询EMPLOYEES表,生成EMOLYEES伪列
                                b.根据分页条件判断该ROWNUM是否与该条件匹配
                                c.条件匹配,取出该条条件
                                d.生成第二个ROWNUM重复r操作
 

2.别名问题
由于ROWNUM的WHERE判断执行在SELECT关键字之前。当前查询中的ROWNUM别名不能用于条件做判断,别名只可以用一外部条件判断(无排序时可以作为<=判断,这时候ROWNUM满足条件)。

3.ROWID是数据库保存记录时候生成的真实物理地址,唯一不变
作用:数据库操作记录使用
         索引值→ROWID→将ROWID换成算成一行数据的物理地址→得到一行数据
如:提取员工表的前三行数据


如:提取4行之后的数据
            错误例子:SELECT ROWNUM,EMP.* FROM EMP WHERE ROWNUM > 3 --错误
            生成第一个ROWNUM(第一列永远是1),进行条件判断是不符合,无法提取结果,结果为NULL
解决方案:先查询带ROWNUM的伪表SELECT ROWNUM,EMP.* FROM EMP查询伪表,选出4条以后的数据SELECT * FROM(SELECT ROWNUM R,EMP.* FROM EMP) RE WHERE RE.R > 3


1.提取工资排行前三的员工

虽然查询了结果,但是并不是前工资排名前三的员工,
原因分析:WHERE条件的执行在ORACLE BY 之前,分页就是先生成了ROWNUM之后才进行,显然者时候序号已经生成好
正确的是SELECT * FROM EMP ORACLE BY SALARY DESC先排序,SELECT ROWNUM,E.* FROM (SELECT * FROM EMP ORACLE BY SAL DESC) E WHERE ROWNUM BETWEEN 1 AND 4

2.提取6到10的记录数据效率

我要提取的数据是6到10之前的数据,把不需要用到的数据过滤掉,提高效率后的写法,只进行提取分页(表数据多是效率会极低)。
如图下。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值