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

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;

上述查询语句的意思是对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()进行分页查询的优点是灵活性高,可以实现各种不同的分页方式,缺点是语法较复杂。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值