分享

oracle中的分页sql为什么这样写

 昵称70680357 2020-07-02

1、分页sql写法:

2、疑问:

为什么不写成这样:

select T.* ,ROWNUM RN from tableName T where ROWNUM <=${pageNumber}*${pageSize} and ROWNUM >(${pageNumber}-1)*${pageSize}

这样写是永远查不出结果的,原因如下:

语言 主方法
4k9AM wWVjJCjdlH
264uE 抖音怎么删除作品
oI211 2vQ49a2fO6

rownum是查询过后才按顺序排的,假如你的条件是rownum>1;那么返回数据的第一条(rownum是1)就不符合要求了,然后第二条数据变成了现在的第一条,结果这一条rownum又变成1了又不符合要求了,以此类推 就没有返回结果。

所以,rownum是虚拟列,是得出结果后,再进行计算的。所以,只能是小于等于,无法大于。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多