美文网首页
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