• Oracle笔记-对ROWNUM的一次理解(简单分页)


    此博文记录时间:2023-05-05,发到互联网上是2023-10-09

    这个在分页里面用得比较多,在MySQL中,通常使用limit去操作,而去感觉比较简单,Oracle中无此关键字。

    通过查阅资料后,要实现分页需要用到ROWNUM,但并ROWNUM ≠ limit。在此记录下。方便以后查阅。

    如下SQL代码:

    select ID, NAME from TEST_TABLE

    执行结果:

    加上ROWNUM关键字后:

    select ROWNUM, ID, NAME from TEST_TABLE

    执行结果:

    可知,他将查询到的数据添加了序号,从1开始。

    如下SQL:

    select ROWNUM, ID, NAME from TEST_TABLE where ID = 1001

    执行结果:

    从中可以看到,他的rownum是1,不是2,这里也就是和MySQL中limit不一样的地方。

    这里可以猜测(无证实,只猜测)ROWNUM是在最后投影时对数据添加序号。

    也就是说,Oracle拿到这个数据后,将表中数据进行选择,选择完成后,再进行投影,然后使用rownum对数据标记序号。

    如果就是要拿到当ID为1001时,对应的ROWNUM为2的SQL,可以这样操作,将第一次查询的数据作为临时表,在临时表中进行查询,即可,如下SQL代码:

    select test.* from (select ROWNUM as rn, ID, NAME from TEST_TABLE) test where ID = 1001

    执行结果如下:

    知道了ROWNUM这些特性后,现在就可以进行分页了,不考虑效率,用最简单的方式就会想到用between关键字。

    规定,每页查2条数据

    那就用这个进行操作下:

    select test.* from (select ROWNUM as rn, ID, NAME from TEST_TABLE) test where rn BETWEEN (page - 1) * 2 + 1 and page * 2  

    如下第一页:

    select test.* from (select ROWNUM as rn, ID, NAME from TEST_TABLE) test where rn BETWEEN (1 - 1) * 2 + 1 and 1 * 2  

    执行结果:

    第三页:

    select test.* from (select ROWNUM as rn, ID, NAME from TEST_TABLE) test where rn BETWEEN (3 - 1) * 2 + 1 and 3 * 2  

    执行结果:

  • 相关阅读:
    如何解决mkdir()提示No such file or directory?
    【Linux】操作题大全
    深入探讨面向对象多态
    Nginx 在线新增模块与Nginx的请求限制limit_req_zone及ab压力测试工具
    JS的正则表达式
    期货开户后需要银期转账绑定
    栈和队列专项练习
    Programming Differential Privacy第八章
    Grafana----基于Kubernetes平台部署Grafana Loki Promtail系统
    Android红外遥控ConsumerIrManager
  • 原文地址:https://blog.csdn.net/qq78442761/article/details/133693435