当前位置: 首页 > news >正文

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  

执行结果:

http://www.lryc.cn/news/187999.html

相关文章:

  • 系统架构设计:10 论数据湖技术及其应用
  • 【MySQL】基本查询(三)聚合函数+group by
  • 基于KubeAdm搭建多节点K8S集群
  • VuePress实现自动获取文章侧边栏目录功能
  • nginx配置实例-负载均衡
  • Nginx的跨域问题解决
  • ts的交叉类型是什么
  • 【【萌新的SOC学习之AXI接口简介】】
  • ios safari 浏览器跳转页面没有自适应
  • node、npm、nvm相关概念区别
  • Dubbo3应用开发—Dubbo3注册中心(zookeeper、nacos、consul)的使用
  • Chrome自动播放限制策略
  • k8s安全机制
  • Java多线程:Runnable与Callable的区别和原理
  • 解决yolo无法指定显卡的问题,实测v5、v7、v8有效
  • arc 166 a
  • Lua05——Lua基本数据类型
  • 一文3000字从0到1使用pytest-xdist实现分布式APP自动化测试
  • pyqt5:pandas 读取 Excel文件或 .etx 电子表格文件,并显示
  • 【QT】Windows 编译并使用 QT 5.12.7源码
  • php实战案例记录(15)获取GET和POST请求参数
  • k8s-9 ingress-nginx 特性
  • java案例24:模拟百度翻译
  • 汽车烟雾测漏仪(EP120)
  • 【轻松玩转MacOS】安全隐私篇
  • 4.02 用户中心-上传头像功能开发
  • 在Ubuntu 18.04安装Docker
  • Vue-2.1scoped样式冲突
  • Matlab之查询子字符串在字符串中的起始位置函数strfind
  • [游戏开发][Unity]安卓出包报错记录