<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
,试了一下,改成
image.pngSELECT * FROM SCHEDULE_JOB WHERE ROWNUM <10
好吧 ,是这个样子。
再试试
image.pngSELECT * FROM SCHEDULE_JOB WHERE ROWNUM <10 AND ROWNUM > 2
突然被掏空。。。。
于是接着去找 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
网友评论