Oracle 三种分页方法(rownum、offset和fetch、row_number() over())

Oracle的三种分页指的是在进行分页查询时,使用三种不同的方式来实现分页效果,分别是使用rownum、使用offset和fetch、使用row_number() over()
1、使用rownum
rownum是oracle中一个伪劣,它用于表示返回的行的序号。使用rownum进行分页查询的方法是在select语句中加入where子句,并在where子句中子句中指定rownum的取值范围,例如
Oracle 三种分页方法(rownum、offset和fetch、row_number() over())_第1张图片

上述查询语句的意思是查询emp表中的前10条记录,然后在这30条记录中取出第5到第10条记录作为结果返回。使用rownum进行分页查询的优点是简单易懂,缺点是在查询大量数据时性能较差。
2、使用offset和fetch , offset [ˈɔːfset] 抵消
offset和fetch是oracle 12c引入的语法,它们可以更方便地实现分页查询。使用offset和fetch进行分页查询的方法是在select语句中加入offset和fetch子句,例如:

select rownum r, a.*
  from emp a
 order by empno offset 4 rows fetch next 5 rows only;

上述查询语句的意思是对emp表按empno列进行排序,然后取出从第5条记录开始的5条记录作为返回。使用offset和fetch进行分页查询的优点是简单方便,缺点是只有在oracle 12C及以上版本才能使用。
3、使用row_number() over()
row_number() over()是oracle中一种用于计算行行号的函数。使用row_number() over()进行分页查询的方法是在select语句中加入row_number() over()函数,并在where子句中指定row_number() over()的取值范围,例如:
Oracle 三种分页方法(rownum、offset和fetch、row_number() over())_第2张图片

上述查询语句的意思是对emp表按照empno列进行排序,然后取出第5到第10条记录作为结果返回。使用row_number() over()进行分页查询的优点是灵活性高,可以实现各种不同的分页方式,缺点是语法较复杂。

你可能感兴趣的:(oracle,数据库,分页,rownum,row_number,over,offset)