首页 > 数据库 >【MySQL】覆盖索引

【MySQL】覆盖索引

时间:2024-03-24 12:29:41浏览次数:28  
标签:覆盖 订单 查询 索引 IO MySQL id

覆盖索引

索引中已经包含了所有需要获取的字段的查询方式称为覆盖索引。

举例说明

假设我们有一个名为orders的数据库表,包含订单信息,其中包括order_id(订单ID)、customer_id(客户ID)、order_date(订单日期)、total_amount(订单总金额)等字段。如果我们经常需要查询某个客户的订单总金额,可以通过覆盖索引来优化这个查询。

我们可以在orders表上创建一个包含customer_idtotal_amount字段的复合索引,这样在查询某个客户的订单总金额时,可以直接从索引中获取数据,无需访问实际的数据行。

假设我们有以下的SQL语句用于查询某个客户的订单总金额:

SELECT total_amount FROM orders WHERE customer_id = '123';

 通过创建覆盖索引,数据库引擎可以直接使用索引来满足这个查询,而不需要再去读取orders表中的实际数据行,从而提高查询性能。 

例2:

# 如果只需要查询 id, code, type 这三列,可建立 code 和 type 的覆盖索引
SELECT id, code, type FROM t_order
ORDER BY code
LIMIT 1000000, 10;

覆盖索引的好处

  • 避免 InnoDB 表进行索引的二次查询,也就是回表操作: InnoDB 是以聚集索引的顺序来存储的,对于 InnoDB 来说,二级索引在叶子节点中所保存的是行的主键信息,如果是用二级索引查询数据的话,在查找到相应的键值后,还要通过主键进行二次查询才能获取我们真实所需要的数据。而在覆盖索引中,二级索引的键值中可以获取所有的数据,避免了对主键的二次查询(回表),减少了 IO 操作,提升了查询效率。
  • 可以把随机 IO 变成顺序 IO 加快查询效率: 由于覆盖索引是按键值的顺序存储的,对于 IO 密集型的范围查找来说,对比随机从磁盘读取每一行的数据 IO 要少的多,因此利用覆盖索引在访问时也可以把磁盘的随机读取的 IO 转变成索引查找的顺序 IO。

但是,当查询的结果集占表的总行数的很大一部分时,可能就不会走索引了,自动转换为全表扫描。当然了,也可以通过 FORCE INDEX 来强制查询优化器走索引,但这种提升效果一般不明显。 

 

标签:覆盖,订单,查询,索引,IO,MySQL,id
From: https://blog.csdn.net/weixin_63541561/article/details/136984402

相关文章

  • 3.MySQL数据库的基本操作-DQL 基本操作
    MySQL数据库的基本操作-DQL基本操作查询select语法格式select[all|distinct]<目标列的表达式1>[别名],<目标列的表达式2>[别名]...from<表名或视图名>[别名],<表名或视图名>[别名]...[where<条件表达式>][groupby<列名>[having<条件表达式>]][o......
  • 在CentOS 7 上安装 MySQL 5.5.50
    点击查看代码rpm-qa|grepmariadb//查看本机是否安装mariadbrpm-emariadb-libs-5.5.68-1.el7.x86_64--nodeps//强制删除mariadbrpm-qa|grepmariadb//检查是否删除成功cd/usr/local///进入安装路径llmkdirmysqlllcdmysqlwgethttps://cdn.mysql.......
  • Java Web项目—餐饮管理系统Day14-MySQL主从复制与读写分离
    文章目录读写分离的作用主从复制(Master-SlaveReplication)如何实现主从复制MySQL配置主库配置从库配置SpringBootsupport读写分离是指将数据库的读操作和写操作分离到不同的数据库服务器上,以提高数据库的性能和可用性。在高并发的场景下,读操作通常占据了大部分......
  • ideaSSM 学员信息管理系统bootstrap开发mysql数据库web结构java编程计算机网页源码mav
    一、源码特点 idea开发SSM学员信息管理系统是一套完善的信息管理系统,结合SSM框架和bootstrap完成本系统,对理解JSPjava编程开发语言有帮助系统采用SSM框架(MVC模式开发),系统具有完整的源代码和数据库,系统主要采用B/S模式开发。前段主要技术bootstrap.cssjquery后端主要......
  • 线路查询||基于Java+Spring Boot+MySQL的公交线路查询系统设计与实现(源码+数据库+文
    目录一、前言二、技术介绍三、系统实现四、论文参考五、核心代码六、其他案例七、源码获取作者介绍:✌️大厂全栈码农|毕设实战开发,CSDN平台Java领域新星创作者,专注于大学生项目实战开发、讲解和毕业答疑辅导。✌️作者博客:曾几何时​​​​​​​......
  • 大数据学习笔记7-Mysql高级
    知识点1:DQL之排序查询--排序查询:就是按照指定字段的大小进行排序,排序规则分为升序和降序--升序(ASC):从小到大依次递增--降序(DESC):从大到小依次递减--关键字:orderby--格式:select列...from表where条件orderby排序规则[ASC|DESC];--0.使......
  • 文章索引
    这里记录所有文章的位置!目前在更新大创以及数模相关1.数学建模(1)习题习题1P562.鲈鱼测量(2)matlab入门(3)建模理论2.大创Ex.1模型介绍Ex.2前置知识III......
  • mysql中的数据类型大全纯干货------------时间日期类型
    简介(类型预览):在mysql8.0版本中支持的类型主要有:YEAR类型表示年DATE类型表示年,月,日TIME类型表示时,分,秒DATETIME类型表示年,月,日,时,分,秒TIMESTAMP类型通常表示带时区的年,月,日,时,分,秒数据类型单位占用字节格式下限上限YEAR年1YYY或YY19012155TIME时间3H......
  • mysql 索引相关操
    1、创建索引    第一种方式:在执行CREATETABLE时创建索引,例如:     CREATETABLEtest(      idINTauto_incrementPRIMARYKEY,      nameVARCHAR(16),      last_nameVARCHAR(16),       id_......
  • Vue3 - Element Plus 下拉选择器 el-select 覆盖修改 placeholder样式,解决覆盖不生效
    前言如果需要Vue2版本,请访问这篇文章。本文实现了在vue3+element-plus网站开发中,完美覆盖el-select选择器样式,强力修改select下拉选择框placeholder样式,同时也支持修改文字、大小、边框、等,支持任意样式的覆盖修改!网上的教程几乎都不生效,使用本教程的方法......