oracle怎么导分页数据,Oracle数据的分页

ps:前一阵子github里找了一个开源框架,是用的mysql数据库,转到Oracle数据库的时候有点不熟悉,sql语句跑起来是各种报错。

有一个sql语句是

SELECT * FROM SCHEDULE_JOB limit ? , ?

在Oracle数据库中跑起来是错的

6e06220c92d3

image.png

没错 就是这个样子。

网上找了一下Oracle的limit ,发现limit是MySQL特有的...

嗯,,好吧。

去找了一下Oracle怎么分页。

网上说用 ROWNUM ,试了一下,改成

SELECT * FROM SCHEDULE_JOB WHERE ROWNUM <10

6e06220c92d3

image.png

好吧 ,是这个样子。

再试试

SELECT * FROM SCHEDULE_JOB WHERE ROWNUM <10 AND ROWNUM > 2

6e06220c92d3

image.png

突然被掏空。。。。

于是接着去找 ROWNUM 不能大于,网上的童鞋是这样回答的

大致意思就是

ROWNUM 是个伪列,该值在被读入cache中时被分配了一个值。每次查询该值都可能变化。同样的一行记录,可能由于读入cache中的行数不同,而导致ROWNUM不同。

当它读固定的值的时候,由于找不到从1开始的值,就会一直找1,没有1的话,就没有结果了。

最后的解决方法,是把ROWNUM全部查出来,然后作为一个字段,子查询查找的。不过很慢。

SELECT * FROM (SELECT ROWNUM RN ,SL.* FROM SCHEDULE_JOB SL ) WHERE RN > 2 AND RN < 10

(主要是一下子查了表的全部数据)

写起来很丑,而且,会把全部的数据给查一遍,然后就想还有没有其他方式。。

SELECT * FROM (SELECT ROWNUM RN ,SL.* FROM SCHEDULE_JOB SL WHERE ROWNUM < 10) WHERE RN > 2

(这次虽然限定了最大行号,但还是在子查询中查了不必要的字段)

终极解决方案:

SELECT

*

FROM

SCHEDULE_JOB OSJ,

( --子查询中 查询定时任务表的前十个行号的id

SELECT

ROWNUM RN,

SL."id"

FROM

SCHEDULE_JOB ISJ

WHERE

ROWNUM < 10

) ISJ

WHERE --判断 父查询和子查询的id一样 并且 行号 > 2

OSJ."id" = ISJ."id"

AND ISJ.RN > 2

OVER

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值