mysql与oracle分页的有什么区别

Java面试:mysql与oracle分页的有什么区别

相信许多人在日常工作中都会用到分页,比如日常查询数据量太大,而我们只需要其中的几条即可,所以这时就会去使用分页去查询,今天主要就mysql与oracle的分页进行分析。

  • MySQL 分页语句简单的写法:

    复制代码
      select * from table limit m,n;  // m = (startPage-1)*pageSize, n = pageSize
  • Oracle 分页语句简单的写法:

    复制代码
      select * from table where rownum <= a;

从上面的sql中我们可以看出两者的写法区别,首先mysql分页用limit,而oracle是用rownum,当然我上面所写的sql仅仅只能满足于随机拿取几条数据的情况,下面我们开始今天的正题,如何两种数据库的分页。

  • 首先我们来讲解mysql的写法

    复制代码
      SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset  

LIMIT 可以接受一个或两个数字参数。参数必须是一个整数常量。如果给定两个参数,第一个参数指定第一个返回记录行的偏移量,第二个参数指定返回记录行的最大数目,初始记录行的偏移量是 0(而不是 1)。

  • 示例

    复制代码
      select * from book limit 2,5;  // 从第三条数据开始拿取5条数据
    
      select* from book limit 5; // 获取前5行数据
  • 接下来看看oracle的分页写法:

    复制代码
      select * from book  where rownum= count;  //count 代表需要获取的行数
      /*
       * 符号使用:= ,> ,< ,>= ,<=
       */
  • 示例

    复制代码
      select * from book where rownum < 10;//获取0-10之间的数据,共9行
    
      select * from (
      	select rownum rn,A.* from book A)
       where rn>5 and  rn<20;    //获取6-20行的数据,不包含第20行
    
      select * from (
      	select rownum rn , A.* from book A where rownum <100 )
      where rn > 50;   //获取51-100的数据,不包含100行
      (注意:此种写法不可用于含有分组查询的时候)

对比这三种写法,绝大多数的情况下,第一个只是拿取数据给定的前几条数据,第二个查询和第三个查询是给定一个查询范围,且第三个查询的效率比第二个高得多。

这 是由于CBO优化模式下,Oracle可以将外层的查询条件推到内层查询中,以提高内层查询的执行效率。对于第三个查询语句,第一层的查询条件WHERE ROWNUM <= 100就可以被Oracle推入到内层查询中,这样Oracle查询的结果一旦超过了ROWNUM限制条件,就终止查询将结果返回了。

而 第二个查询语句,由于查询条件BETWEEN 5 AND 20是存在于查询的第二层,而Oracle无法将第二层的查询条件推到最内层(即使推到最内层也没有意义,因为最内层查询不知道RN代表什么)。因此,对 于第二个查询语句,Oracle最内层返回给中间层的是所有满足条件的数据,而中间层返回给最外层的也是所有数据。数据的过滤在最外层完成,显然这个效率 要比第一个查询低得多。

上面分析的查询不仅仅是针对单表的简单查询,对于最内层查询是复杂的多表联合查询或最内层查询包含排序的情况一样有效。

相关推荐
铁皮哥3 分钟前
【后端开发】什么是守护线程,和普通线程有什么区别?
java·开发语言·数据库·人工智能·python·spring·intellij-idea
~央千澈~4 分钟前
《ZAKU渗透论:卓伊凡的2026渗透工程》第三章:Web攻击原理(上)——注入与SQL注入
数据库·sql·oracle
AI人工智能+电脑小能手11 分钟前
【大白话说Java面试题 第86题】【Mysql篇】第16题:MySQL 中锁的种类与行锁实现原理?
java·开发语言·数据库·mysql·面试
染指111011 分钟前
14.LangChain框架5-文档切分
数据库·人工智能·ai·langchain
abcy07121314 分钟前
【无标题】
数据库·sqlite
code2roc16 分钟前
SpringBoot整合Milvus向量数据库
数据库·spring boot·milvus·向量化
AugustRed18 分钟前
Flyway 数据库版本迁移 零基础完整学习文档
数据库·学习
Yvonne爱编码25 分钟前
数据库---Day9 视图(附完整数据库脚本+练习题)
数据库·mysql·oracle
sukioe27 分钟前
Redis 入门:为什么出现、核心原理与安装配置
数据库·redis·缓存
宇砾31 分钟前
浅谈Redis(1)
数据库·redis·缓存