SELECT a.* FROM 表 1 a, (select id from 表 1 where 条件 LIMIT 100000,20 ) b where a.id=b.id

覆盖 索引 必须 要 存储 索引 列 的 值,假设 索引 覆盖 了 WHERE 条件 中的 字段, 但不 是 整个 查询 涉及 的 字段。 如果 条件 为 假( false), MySQL 5. 5 和 更早 的 版本 也 总是 会 回 表 获取 数据 行, 尽管 并不 需要 这 一行 且 最终 会被 过 滤掉。

使用延迟关联和覆盖索引对查询进行优化

测试结果来自 高性能MySQL

查询 返回 了 一个 很大 的 结果 集, 因此 看不 到 优化 的 效果。 大部分 时间 都 花在 读取 和 发送 数据 上了。

经过 索引 过滤, 过滤后 的 结果集 已经很少了,所以 优化效果 明显

子 查询 效率 反而 下降 因为 索引 过滤 时 符合 第一个 条件 的 结果 集 已经 很小, 所以 子 查询 带来 的 成本 反而 比 从 表中 直接 提取 完整 行 更高。

当从一个数据集中过滤出很少的结果集时,优化效果显著。当数据集过滤出很多结果集、优化效果一般,数据集本身很少时,优化效果反而下降

SQL 性能优化的目标:至少要达到 range 级别,要求是 ref 级别,如果可以是consts 最好。

摘自阿里Java开发规约

consts 单表中最多只有一个匹配行(主键或者唯一索引),在优化阶段即可读取到数据。

ref 指的是使用普通的索引(normal index)。

range 对索引进行范围检索。

反例:explain 表的结果,type=index,索引物理文件全扫描,速度非常慢,这个 index 级别比较 range还低,与全表扫描是小巫见大巫

【推荐】建组合索引的时候,区分度最高的在最左边。

正例:如果 where a=? and b=? ,如果 a 列的几乎接近于唯一值,那么只需要单建 idx_a 索引即可。

说明:存在非等号和等号混合时,在建索引时,请把等号条件的列前置。

如:where c>? and d=? 那么即使 c 的区分度更高,也必须把 d 放在索引的最前列,即索引 idx_d_c。

【强制】在 varchar 字段上建立索引时,必须指定索引长度,没必要对全字段建立索引,根据实际文本区分度决定索引长度即可。

说明:索引的长度与区分度是一对矛盾体,一般对字符串类型数据,长度为 20 的索引,区分度会高达

90%以上,可以使用 count(distinct left(列名, 索引长度))/count(*)的区分度来确定。

【强制】页面搜索严禁左模糊或者全模糊,如果需要请走搜索引擎来解决。

说明:索引文件具有 B-Tree 的最左前缀匹配特性,如果左边的值未确定,那么无法使用此索引。

【推荐】如果有 order by 的场景,请注意利用索引的有序性。order by 最后的字段是组合索引的一部分,并且放在索引组合顺序的最后,避免出现 file_sort 的情况,影响查询性能。

正例:where a=? and b=? order by c; 索引:a_b_c

反例:索引如果存在范围查询,那么索引有序性无法利用,如:WHERE a>10 ORDER BY b; 索引 a_b 无法排序

jmr连接mysql_MYSQL 优化之延迟关联相关推荐

  1. 【MySQL】 性能优化之 延迟关联

    [背景] 某业务数据库load 报警异常,cpu usr 达到30-40 ,居高不下.使用工具查看数据库正在执行的sql ,排在前面的大部分是: SELECT id, cu_id, name, inf ...

  2. 百万数据量下,使用延迟关联优化超大分页

    百万数据量下,使用延迟关联优化超大分页 MySQL 并不是跳过 offset 行,而是取 offset + N 行,然后返回放弃前 offset 行,返回 N 行,那当offset 特别大的时候,效率 ...

  3. left join 临时表_不懂SQL优化?那你就OUT了——表连接的优化

    上一遍我们讨论了where 子句的优化,这一遍我们来讨论一下表连接的优化 我们知道在数据库中表连接有两种方式: 1. 内连接(inner join)2. 外连接(左外连接(left join), 右外 ...

  4. mysql延迟关联为什么快_MySQL 覆盖索引与延迟关联详解

    本期来谈谈覆盖索引与延迟关联.在此之前,我们先简单建立一个订单表 Orders 用于举例说明.表中共包含 3 个字段: id int product_id name CREATE TABLE `ord ...

  5. Loadrunner脚本优化-参数化之关联MySQL数据库获取数据

    脚本优化-参数化之关联MySQL数据库获取数据 by:授客 QQ:1033553122 测试环境: Loadrunner 11 Win7 64位 实操: 1.   安装MySQL ODBC驱动程序 O ...

  6. 企业网络带宽需求和跨地域网络连接的优化

    SD-WAN仍然是一项相对年轻的技术,虽然已取得重大进展,但还有很长的路要走,属于SD-WAN的市场远未稳定下来. 一项调查发现,36%的受访者表示,由于网络基础架构和性能任务的复杂性不断提高,他们正 ...

  7. Linux基础优化方法(四)———远程连接缓慢优化

    Linux基础优化方法(四)---远程连接缓慢优化 一.优化原因 二.优化方法 第一步:修改SSH服务配置文件 /etc/ssh/sshd_config 第二步:修改/etc/hosts配置文件 第三 ...

  8. mysql innodb 索引 延迟更新_Mysql覆盖索引与延迟关联

    延迟关联:通过使用覆盖索引查询返回需要的主键,再根据主键关联原表获得需要的数据. 为什innodb的索引叶子节点存的是主键,而不是像myisam一样存数据的物理地址指针? 如果存的是物理地址指针不就不 ...

  9. 基于闪电连接过程优化算法的函数寻优算法

    文章目录 一.理论基础 1.闪电连接过程优化算法 (1)初始化 (2)确定闪电的下一跳 (3)闪电分支消失 (4)上迎先导的移动 (5)连接点的确定 2.LAPO算法伪代码 二.仿真实验与结果分析 三 ...

最新文章

  1. [深入浅出Cocoa]iOS网络编程之Socket
  2. idea在Mybatis的xml里面写sql时,表名、字段、报红问题的解决方法
  3. 多通道图像的通道分享和合成函数-split、merge
  4. Chrome 技术篇-json查看,json格式化,JSONView插件
  5. 5、继承与派生4-派生类的构造和析构函数
  6. 如何成长为一名优秀的Web开发人员
  7. WWW 2020 | 信息检索中的对话式问题建议
  8. python去重复的数据_Python中mysql查询重复数据并删除重复数据
  9. jQuery使用ajax传输xml文档在IE中无法正确解析的问题
  10. 线性判别结合源码分析LDA原理
  11. python 行为驱动_什么是行为驱动的Python?
  12. PostgreSQL 12 的同步流复制搭建及主库hang问题处理与分析
  13. 新建网站了!Github标星过万的吴恩达机器学习、深度学习课程笔记,《统计学习方法》代码实现,可以在线阅读了!...
  14. collector_使用Data Collector进行SQL Server性能监视–第3部分–阅读报告
  15. u2 接口 服务器硬盘,M.2、U.2谁更好?主流硬盘接口都有哪些?
  16. qq服务器上的文件删除后如何恢复,QQ文件失效怎么恢复(过期的QQ文件如何申请恢复)...
  17. 博客园博客排版(js样式实例)
  18. 组装台式计算机的过程,学习电脑装机全过程 组装台式机图解教程(6)
  19. 通过whoscored网站对转会球员的评分来比较五大联赛水平高低
  20. Memwatch简介

热门文章

  1. 返回值类型与函数类型不匹配_C++返回值类型后置(跟踪返回值类型)
  2. 有监督回归:鲁棒学习
  3. delphi 垃圾回收框架
  4. 【解惑】这么多技术我该怎么学
  5. 【CyberSecurityLearning 44】iptables包过滤与网络地址转换
  6. Chrome和Firefox中安装Hackbar插件
  7. 关于jquerymobile的预加载
  8. 【快乐水题】1688. 比赛中的配对次数
  9. ifstream 打开中文路径乱码问题处理
  10. 消息队列之JMS和AMQP对比