首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL 案例:Limit 分页查询优化

MySQL 支持的 SQL 语法对此有特殊的支持,开发人员在实现这类功能的时候很方便: select * from xxx limit M,N select * from xxx limit N...可以看到跳过的行数大幅度增长时,SQL 语句的执行时间也会快速增长,原因其实比较简单:在处理 limit M,N 的时候,MySQL 会先拿到 M+N 行结果数据,然后再丢弃 M 行数据,展示之后剩下的...在分页查询的时候,记录上一次查询结果的主键,然后在 where 条件添加主键的范围约束。...limit查询基本是马上返回结果的。...总结一下 MySQL 由于本身查询优化器覆盖到的场景不够全,慢查询的原因也千奇百怪,各类业务 SQL 在上线前尽量多覆盖一些场景,确保业务功能安全发布。

3.5K4432
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL多表关联查询

    左连接与右连接的左右指的是以两张表的哪一张为基准,它们都是外连接。外连接就好像是为非基准表添加了一行全为空值的万能行,用来与基准表找不到匹配的行进行匹配。...,也从左表返回所有的行 RIGHT JOIN:即使左表没有匹配,也从右表返回所有的行 FULL JOIN:只要其中一个表存在匹配,则返回行(MySQL不支持FULL JOIN) 实例表1:...LEFT JOIN 关键字从左表(table1)返回所有的行,即使右表(table2)没有匹配。...如果右表没有匹配,则结果为 NULL mysql> SELECT w.name, a.count, a.date FROM websites w LEFT JOIN access_log a ON w.id...RIGHT JOIN 关键字从右表(table2)返回所有的行,即使左表(table1)没有匹配。如果左表没有匹配,则结果为 NULL。

    5K20

    Mysqllimit的用法

    目录 目录 前言 limit语法 性能分析 优化 用id优化 用覆盖索引优化 总结 前言 日常开发,我们使用mysql来实现分页功能的时候,总是会用到mysqllimit语法.而怎么使用却很有讲究的...性能分析 实际使用我们会发现,在分页的后面一些页,加载会变慢,也就是说: select * from user limit 1000000,10 语句执行较慢.那么我们首先来测试一下....优化 用id优化 先找到上次分页的最大ID,然后利用id上的索引来查询,类似于select * from user where id>1000000 limit 100....用覆盖索引优化 mysql查询完全命中索引的时候,称为覆盖索引,是非常快的,因为查询只需要在索引上进行查找,之后可以直接返回,而不用再回数据表拿数据.因此我们可以先查出索引的ID,然后根据Id拿数据....联系邮箱:huyanshi2580@gmail.com 更多学习笔记见个人博客——>呼延十 var gitment = new Gitment({ id: 'Mysqllimit的用法', //

    11.2K20

    mysqllimit查询竟然有坑?

    背景 最近项目联调的时候发现了分页查询的一个bug,分页查询总有数据查不出来或者重复查出。 数据库一共14条记录。 如果按照一页10条。那么第一页和第二页的查询SQL和和结果如下。...,查询结果显然不是按照某一列排序的(很乱)。...分析问题 为什么limit查询不加order by就会出现 分页查询总有数据查不出来或者重复查出? 是不是有隐含的order排序? 此时explain登场(不了解的百度)。...索引的作用有两个:检索、排序 因为两个SQL使用了不同的索引(排序规则),索引limit出来就会出现上面的问题,问题解开了。...总结 一说MySQL优化大家都知道explian,但是真正有价值的是场景,是让你的知识落地的场景。实践出真知。

    17710

    THINKPHP 关联查询(多表查询)

    THINKPHP 关联查询(多表查询)可以使用 table() 方法或和join方法,请看示例: 1、Table方法:定义要操作的数据表名称,可以动态改变当前操作的数据表名称,需要写数据表的全名,包含前缀...) ->field('blog.id as id,blog.title,blog.content,type.typename as type') ->order('blog.id desc' ) ->limit...2、Join方法:查询Join支持,Join方法的参数支持字符串和数组,并且join方法是连贯操作唯一可以多次调用的方法。...*,N.*') ->order('id desc') ->limit('8') ->findall(); 如果join方法的参数用数组的话,只能使用一次join方法,并且不能和字符串方式混合使用。...$sort.' limit '.$p->firstRow.','.$p->listRows; $voList = $Model->query($sql);

    4.5K30

    mysql 多表查询和更新_MySQL update select 多表关联查询更新

    在遇到需要update设置的参数来自从其他表select出的结果时,需要把update和select结合使用,不同数据库支持的形式不一样,在mysql如下: update A inner join(select...sql语句就如上所示 参考文章: * [UPDATE从SELECT使用SQL Server – 代码日志](https://codeday.me/bug/20170212/192.html) * [MySQL...多表关联UPDATE操作 – jsyandxys的博客 – CSDN博客](https://blog.csdn.net/jsyandxys/article/details/83584410) * [mysql...update和select结合使用 – 404NotFound的博客 – CSDN博客](https://blog.csdn.net/qq_36823916/article/details/79403696...) * [MySQL – update 与 select 的相爱相杀 – 知乎](https://zhuanlan.zhihu.com/p/23011325) 发布者:全栈程序员栈长,转载请注明出处:https

    3.8K10

    MySQL | 使用 limit 优化查询和防止SQL被优化

    ---- Table of Contents 查询优化1.1 最大值和最小值的优化1.2 优化 limit 分页1.2.1 使用关联查询优化1.2.2 使用范围查询1.2.3 利用唯一自增序列进行查询防止被优化参考...1.2 优化 limit 分页 在系统进行分页操作的时候,当偏移量大时,例如:limit 10000,20 时,MySQL 需要查询 10020 条记录然后只返回 20 记录,前面的记录全部被舍弃,这样的代价非常高...1.2.1 使用关联查询优化 优化此类查询一个简单的方法就是尽可能地使用索引覆盖扫描,而不是查询所有的列,然后根据需要做一次关联操作再返回所需的列。对于偏移大的时候,这样的效率提升非常大。...20 ) AS LIM USING(id) 1.2.2 使用范围查询 有时候可以将 LIMIT 转化为已知位置的查询,让 MySQL 通过范围扫描获得到对应的结果。...,在一些操作可以改为传入上一次查询到的自增序列,然后往后查询对应的每页数量即可。

    1.4K20

    MySQL如何破解limit 100w+的分页查询

    版本:MySQL 5.7 三、优化前 我们先不进行任何优化处理,直接采用最原始的limit方式查询,如下SQL: select type from order_info where user_id =...17898735496 limit 2000000,10 执行结果: > OK > 时间: 42.698s 执行结果表明,虽然查询很简单,但是因为limit翻页数量太大,导致这个SQL查询时间非常慢。...查询,所以我们可以在程序上面一下处理。...如果limit index小于1w,就直接查询所有的数据,如果limit index大于等于1w,就采用先查询id,后in条件查询所有数据。...六、结论: 我们可以很明显的看到,通过只查询id的方式,可以快速查询出所有的id主键,因为MYSQL查询主键是有进行特殊优化的,可以直接走主键索引,不需要回表操作。

    1K10

    mysql分页查询limit用法(怎么对文档进行分页)

    一、分页需求: 客户端通过传递start(页码),pageSize(每页显示的条数)两个参数去分页查询数据库表的数据,那我们知道MySql数据库提供了分页的函数limit m,n,但是该函数的用法和我们的需求不一样...,所以就需要我们根据实际情况去改写适合我们自己的分页语句,具体的分析如下: 比如: 查询第1条到第10条的数据的sql是:select * from table limit 0,10; ->对应我们的需求就是查询第一页的数据...:select * from table limit (1-1)*10,10; 查询第11条到第20条的数据的sql是:select * from table limit 10,10; ->对应我们的需求就是查询第二页的数据...:select * from table limit (2-1)*10,10; 查询第21条到第30条的数据的sql是:select * from table limit 20,10; ->对应我们的需求就是查询第三页的数据...三、附文: 上文仅介绍了MySQL分页的计算公式,如果数据较多时直接使用limit会耗时比较长,详情请阅读: https://www.cnblogs.com/youyoui/p/7851007.html

    1.8K30

    Mysql关联查询(内连接,外连接,自连接)

    在使用数据库查询语句时,单表的查询有时候不能满足项目的业务需求,在项目开发过程,有很多需求都是要涉及到多表的连接查询,总结一下mysql的多表关联查询 一,内连接查询 是指所有查询出的结果都是能够在连接的表中有对应记录的...(这里只是举例,可能与实际不符,但主要在于逻辑关系),而赵七没有对应的部门,现在想要查询出员工姓名以及其对应的部门名称: 此时,就要使用内连接查询,关键字(inner join) 在这里说一下关联查询sql...,如果右表没有记录对应的话就显示null 查询结果: 关键字是left outer join,等效于left join,在关联查询外连接查询就是左连接查询,两者是一个概念 三,右外连接是同理的...顾名思义,把两张表的字段都查出来,没有对应的值就显示null,但是注意:mysql是没有全外连接的(mysql没有full outer join关键字),想要达到全外连接的效果,可以使用union关键字连接左外连接和右外连接...所以,自连接查询一般用作表的某个字段的值是引用另一个字段的值,比如权限表,父权限也属于权限。

    3.8K40
    领券