码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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  

    执行结果:

  • 相关阅读:
    NAACL2022中Prompt相关论文分类
    基于Python+html+javascript+boostrap实现的疫情传播模拟系统
    java计算机毕业设计学生健康信息管理源程序+mysql+系统+lw文档+远程调试
    作业2 计算文件长度和行数
    基本微信小程序的新冠疫苗预约小程序
    【vue3项目】解决 “TypeError: Cannot read properties of undefined (reading ‘xxx‘)“
    Vue.js+Node.js全栈开发教程:Vue.js方法详解
    LeetCode每日两题01:有序数组的平方 (均1200道)方法:双指针
    智能化燃气场站建设4要点!
    Java JVM 中 堆,栈,方法区 详解
  • 原文地址:https://blog.csdn.net/qq78442761/article/details/133693435
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号