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

没有Sql Server有top那么好用,但是Oracle含有隐藏的rownum列可以灵活使用,使实现分页效果,pageSize默认10行

方法一:

select * from test where id not in (
select id from test where rownum <= 10)
and rownum <= 10 order by id
/--此方法除去前10行数据,剩下的重新排序,选取前十行,相当于第二页显示

方法二:

SELECT * from test where  rownum <= 20 
minus
select * from test  where rownum <= 10
/
--此方法使用关键字minus 选出两页 再排除第一页 数据 ,使其显示第二页数据

方法三:

select id ,name from(
select rownum as rowno,t.* from test t where rownum <= 20) 
where rowno > 10
/--此方法把rownum直接显式保存到结果集中,然后根据rowno方便选取数据,与方法一,类似..

  以上三种方法有严重的缺陷,分页一般是排序之后再分页,以上方法都没有实现排序,所以基本没有实际意义的,所以实际运用中要先排序,然后再进行分页

例如

select sno, sname, cname, degree from --最外层的table是利用rownum别名,查找出最终需求的记录(确定最小记录数)
				(        --中间这个table是含有rownum where条件的,查找出已经排好序的最大 需求行以内记录(确定最大记录数)     
                                        select sno, sname, cname , degree,rownum r from
                                          (              --最里边这个是先排序后查找的table                             
                                                 select i.sno,sname,cname,degree 
                                                 from score s ,info i , course c 
                                                 where s.sno = i.sno and c.cno = s.cno 
                                                 order by i.sno asc
                                           )  
                                        where rownum <= 10
                                )
				 where r > 5 
         
--最大记录数与最小记录数存在某种数学关系(rows = max - min),可在逻辑中使用                    

  

  

原文地址:https://www.cnblogs.com/whytohow/p/5026343.html