当前位置:   article > 正文

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

oracle offset

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

上述查询语句的意思是查询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;
  • 1
  • 2
  • 3

上述查询语句的意思是对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()的取值范围,例如:
在这里插入图片描述

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/475352
推荐阅读
相关标签
  

闽ICP备14008679号