MySQL 的覆盖索引是什么?

覆盖索引(Covering Index)是指索引本身包含了查询所需的所有字段数据,从而无需再回表查询的数据访问方式。这种优化能够显著提升查询性能。


1. 覆盖索引的特点

  • 查询所涉及的字段都在索引中能够找到。
  • 不需要访问表的聚簇索引或主键索引即可满足查询。
  • 在一定程度上减少了磁盘 I/O,提升了查询效率。

2. 示例分析

(1)表结构与索引

假设有如下表结构:

CREATE TABLE users (

id INT PRIMARY KEY,

name VARCHAR(50),

age INT,

email VARCHAR(100),

KEY idx_name_age (name, age)

);

(2)覆盖索引的查询

执行以下查询:

SELECT name, age FROM users WHERE name = 'Alice';

  • 过程

    1. 查询需要的字段是 nameage
    2. 索引 idx_name_age 包含了 nameage 两个字段的数据。
    3. MySQL 可以直接通过索引完成查询,无需回表访问 users 表。

(3)非覆盖索引的查询

执行以下查询:

SELECT name, age, email FROM users WHERE name = 'Alice';

  • 过程

    1. 查询需要的字段是 name, age, 和 email
    2. 索引 idx_name_age 不包含 email
    3. MySQL 通过索引 idx_name_age 查找到符合条件的主键值 id,然后回表查询 email

3. 覆盖索引的优点

  • 减少磁盘 I/O:数据直接从索引中读取,无需回表访问主表。
  • 提升查询速度:索引通常比主表小,访问更高效。
  • 降低存储成本:对热点查询优化有效,避免多次随机磁盘读写。

4. 覆盖索引的实现方式

  • 通过索引覆盖所有查询字段

    • 将查询中涉及的所有字段添加到索引中。

示例:

CREATE INDEX idx_name_age_email ON users(name, age, email);

  • 尽量减少查询的字段数量

    • 查询字段越少,索引越容易覆盖。

5. 注意事项

  1. 索引大小问题

    • 索引覆盖更多字段会占用更多磁盘空间,影响写性能。
  2. 查询字段与索引顺序

    • 查询字段的顺序应与索引设计匹配,以便 MySQL 能高效利用覆盖索引。
  3. 覆盖索引与最左前缀原则的结合

    • 查询中字段的匹配需要符合联合索引的最左前缀原则。

6. 覆盖索引的适用场景

  • 高频次的读操作:如统计查询、排序等。
  • 需要快速响应的查询:如分页查询。
  • 涉及较少列的简单查询:减少回表次数,提升效率。

7. 总结

覆盖索引通过索引自身满足查询的所有需求,避免了回表操作,是 MySQL 中提升查询效率的重要优化手段。合理设计覆盖索引,不仅可以加速查询,还能降低系统的资源消耗。

MySQL 的覆盖索引是什么?的更多相关文章

  1. 理解MySQL数据库覆盖索引

    话说有这么一个表: CREATE TABLE `user_group` ( `id` int(11) NOT NULL auto_increment, `uid` int(11) NOT NULL, ...

  2. 理解MySQL数据库覆盖索引 (转)

    http://www.cnblogs.com/zl0372/articles/mysql_32.html 话说有这么一个表: CREATE TABLE `user_group` ( `id` int( ...

  3. 【MySQL】覆盖索引和回表

    先来了解一下两大类索引 聚簇索引(也称聚集索引,主键索引等) 普通索引(也成非聚簇索引,二级索引等) 聚簇索引 如果表设置了主键,则主键就是聚簇索引 如果表没有主键,则会默认第一个NOT NULL,且 ...

  4. mysql优化-覆盖索引查询,join

    1 原始sql: SELECT a.* FROM event_data a WHERE a.receive_time >= '2018-03-28 00:00:00' AND a.receive ...

  5. MySQL 覆盖索引

    通常大家都会根据查询的WHERE 条件来穿件合适的索引,不过这只是索引优化的一个方面.设计优秀的索引应该考虑到整个查询,而不单单是WHERE 条件部分.索引确实是一种查找数据的高效方式,但是MySQL ...

  6. 制作mysql大数据表验证覆盖索引

    昨天跟同事聊起数据表性能的问题,能不能仅用覆盖索引实现数据的汇总统计.找了一个开发环境已有的数据表进行测试,通过explain命令,能看到mysql通过覆盖索引就能实现sum的需求,而无须去读取实际行 ...

  7. MySQL 创建高性能索引

    索引是存储引擎用于快速找到记录的一种数据结构.除了加速查找,索引在其他方面也有一些有用的属性.索引对于良好的性能非常关键.尤其是当表中的数据量越来越大时,索引对性能的影响愈发重要.在数据量较小且负载较 ...

  8. mysql延迟查询, 覆盖索引使用例子

    引用自 'mysql高性能' 5.3.6章节 不能使用覆盖索引的情况 :  解决办法 : 

  9. MYSQL的全表扫描,主键索引(聚集索引、第一索引),非主键索引(非聚集索引、第二索引),覆盖索引四种不同查询的分析

    文章出处:http://inter12.iteye.com/blog/1430144 MYSQL的全表扫描,主键索引(聚集索引.第一索引),非主键索引(非聚集索引.第二索引),覆盖索引四种不同查询的分 ...

  10. mysql覆盖索引详解

    覆盖索引的定义: 如果一个索引包含(或覆盖)所有需要查询的字段的值,称为‘覆盖索引’.即只需扫描索引而无须回表. 只扫描索引而无需回表的优点:    1.索引条目通常远小于数据行大小,只需要读取索引, ...

随机推荐

  1. System类、Math类、BigInteger与BigDecimal的使用

     System类代表系统,系统级的很多属性和控制方法都放置在该类的内部.该类位于java.lang包. 由于该类的构造器是private的,所以无法创建该类的对象,也就是无法实例化该类.其内部的成 ...

  2. 如何安全发布 CompletableFuture ?Java9新增方法分析

    如何安全发布 CompletableFuture ?Java9新增方法分析 本文未经允许禁止转载. JDK9 中对于CompletableFuture做了新的增强,除了超时功能(orTimeout), ...

  3. Linux安装Python 3.11

    Linux安装python 在Linux上安装Python 3.11,你可以按照以下步骤进行.这些步骤以CentOS为例,但其他Linux发行版的过程大同小异,可能只需稍作调整. 1. 检查Pytho ...

  4. 使用Reids实现简单消息队列

    队列操作 简单队列 利用List数据结构可以实现简单的队列,在于使用List提供插入和移除api来完成简单队列操作: 准备数据 获取数据 后入先出 使用redis提供的apiLPOP可以从队列左边获取 ...

  5. Thymeleaf 嵌套循环

    <label th:each="role:${roles}" class="check-box"> <input th:each=" ...

  6. 【Manim】空间与变换笔记

    [Manim]空间与变换笔记 所有常量都可以在constants.py中找到 屏幕空间 屏幕中心为原点(0,0,0),遵循右手坐标系,向右为x轴正方向,向上为y轴正方向,向前为z轴负方向,旋转时正方向 ...

  7. RNN、lstm和GRU推导

    RNN:(Recurrent Neural Networks)循环神经网络 第t层神经元的输入,除了其自身的输入xt,还包括上一层神经元的隐含层输出st−1 每一层的参数U,W,V都是共享的 lstm ...

  8. Typecho获取当前页面加载完成速度时间

    判断当前页面加载是否快速,通常是直接在浏览器中访问网站,看自己的直观感受是否快速.而客观的方法则是计算具体的页面加载时间并显示出来给看. 1.在当前主题的functions.php文件添加下面的代码: ...

  9. vue - [04] 配置

    关闭ESLint. 001 || ESLint (1)定义   ESLint是一个插件化的JavaScript代码检查工具.在vue项目中,它可以检查.vue文件中的JavaScript代码(包括脚本 ...

  10. gitlab - [02] 安装部署

    安装部署篇 一.5分钟搭建私人代码仓库 (1)设置环境变量:export GITLAB_HOME=/src/gitlab (2)编写docker-compose.yml mkdir -p /opt/d ...