美文网首页
Oracle数据的分页

Oracle数据的分页

作者: 许笑山 | 来源:发表于2017-11-22 14:33 被阅读0次

<link href="http://kevinburke.bitbucket.org/markdowncss/markdown.css" rel="stylesheet"></link>

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

有一个sql语句是

SELECT * FROM SCHEDULE_JOB limit ? , ?

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


image.png

没错 就是这个样子。

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

去找了一下Oracle怎么分页。
网上说用 ROWNUM ,试了一下,改成

SELECT * FROM SCHEDULE_JOB WHERE ROWNUM <10

image.png

好吧 ,是这个样子。

再试试

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

image.png

突然被掏空。。。。

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

网上结果,点击跳转----查询条件为ROWNUM=2没有结果

大致意思就是

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

相关文章

网友评论

      本文标题:Oracle数据的分页

      本文链接:https://www.haomeiwen.com/subject/njinvxtx.html