Oracle的分页是通过rownum实现的
rownum是一个伪列是oracle系统自动为查询返回结果的每行分配的编号第一行为第二行为以此类推
一个oracle分页至少要包含三层(除非不用order by暂时可以用层实现)模板为
select temp* from(
select rownum numtemp* from(
SQL查询
) temp where rownum<=n
)temp where tempnum>n
例如值返回查询结果第条到条着条的信息的SQL如下
select temp*
from(
select rownum numtemp*
from(
select tttitle_idttname
from t_title tt
where ttname like %美%
order by ttsort_seqs asctttitle_Id desc) temp
where rownum<=
)temp
where tempnum>
分析
首先是一个正常的查询语句(包含order by)
select tttitle_idttname
from t_title tt
where ttname like %美%
order by ttsort_seqs asctttitle_Id desc
这个和正常的SQL语句没有任何的区别
添加rownum字段显示列数
select rownum numtemp*
from(
select tttitle_idttname
from t_title tt
where ttname like %美%
order by ttsort_seqs asctttitle_Id desc) temp
where rownum<=
我们添加了rownum 显示字段这时候就会会每行添加一个行数的编号并且只返回条之前的数据(包含条)
截取第条到条的数据SQL就是上面最完整的那个啦
使用精解
rownum的使用
如下两条语句
select rownumidname from student where rownum>;
select rownumidname from student where rownum<=;
第一条语句的执行结果为空第二条语句的执行结果为前条记录
为什么会这样呢我们知道rownum是伪列是oracle为查询结果自动添加的伪列第一行是如果where rownum>这时候查找第一条发现它的rownum=不满足条件于是抛弃掉把第二条语句的rownum赋值为再判断第二条记录是否满足条件同样不满足于是发生了死循环一样的判断最终返回空
有人这时候就奇怪啦为什么第一条记录rownum=不满足条件时候第二条记录rownum=却要重新设值为呢非常简单你直接在where后添加了条件rownum>它是个条件啦第一条记录不满足条件叫抛弃掉啦这时候结果集是空的当然会一直rownum=的赋值
解决办法:先查询并为每条记录分配rownum然后嵌套查询
select t* from (select rownum numidname from student) t where tnum>
第二条语句可以正常的执行根据上面的解释这个可以理解了吧!
rownum与order by同时存在的问题
当 where 后面有rownum的判断并且存在order by时候rownum的优先级高!
oracle会先执行rownum的判断然后从结果中order by很明显是错误的结果啦!就好像学校要取成绩最好的前名同学结果这种方法一执行成了取出名同学然后按照成绩的高低排序!
这点与SQL Server的TOP完全不同TOP遇上order by是先执行order by在分页的
解决办法就是先执行order by然后嵌套执行rownum说白啦就是用()改变函数的优先级!