MySQL 索引

MySQL 索引

文章目录

  • MySQL 索引
    • 1. 索引概念
    • 2. 索引结构
    • 3. 索引分类
    • 4. 索引使用
      • 4.1 单列索引和联合索引
      • 4.2 覆盖索引
      • 4.3 前缀索引
    • 5. SQL提示
    • 6. 索引失效情况

1. 索引概念

索引可以理解为MySQL中用来高效检索数据的数据结构,它是有序的,因为它底层使用的数据结构是B+树;

索引的设计原则上看,一般建议根据以下方式建立索引:

  • 针对于数据量较大,且查询比较频繁的表建立索引;
  • 针对于常用作查询条件(where)、排序(order by)、分组(group by)操作的字段建立索引;
  • 尽量选择区分度高的列作为索引,如唯一索引,这样使用索引的效率更高;
  • 尽量使用联合索引,减少单列索引,因为联合索引很多时候能够实现覆盖索引,避免回表查询,提高查询效率;
  • 需要控制索引数量,索引不是越多越好,索引越多,维护索引结构的代价就越大,会影响增删改操作的效率;

2. 索引结构

常见的有B+树索引结构和Hash索引结构,InnoDB存储引擎默认使用的就是B+树作为索引结构

B+树:数据都只存储在叶子节点中,而非叶子节点只用来进行索引,且叶子节点上维护了一条单向链表用来高效查询数据(InnoDB中维护的是双向链表);

至于InnoDB为什么使用B+树而不使用其它数据结构作为索引结构

  • 使用二叉树的话,当数据存储时使用的是顺序存储的话,层数将会变得很大,索引效率会大大降低;
  • B树它的数据不仅存储在叶子节点中,也存储在非叶子节点中,而InnoDB中一片能够存储容量有限,只能存16KB,又要存字段又要存数据,一旦数据量大起来了,需要的层数就会变多,而索引效率就会降低,而B+树的话数据都是存储在叶子节点中的,数据量大起来了对B+树层数的影响也不会很大;
  • Hash索引本身索引效率是比B+Tree高的,但是在未出现哈希碰撞之前是这样,出现哈希碰撞后还需要通过添加链表的方式来解决,效率会下降,同时Hash索引本身并不支持范围查询以及排序操作,而B+树支持;

3. 索引分类

在MySQL数据库中,索引可以具体分为以下几类:

分类含义特点关键字
主键索引针对于表中主键创造的索引若有主键默认自动创建,且只有一个PRIMARY
唯一索引避免同一个表中某数据列中的值重复可有多个UNIQUE
常规索引快速定位特定数据可有多个
全文索引查找的是文本中的关键词,而本身比较索引中的值可有多个FULLTEXT

而在InnoDB存储引擎中,根据索引的存储格式可以分为以下两类:

分类含义特点
聚集索引索引结构的叶子节点存放行数据必须有,且只能存在一个
二级索引索引结构的叶子节点存放主键值可有多个

对于聚集索引来说:

  • 若存在主键(PRIMARY KEY),则主键索引就是聚集索引;
  • 若不存在主键,则第一个唯一(UNIQUE)索引就是聚集索引;
  • 若主键和唯一索引都不存在,则InnoDB会自动创建一个rowid作为隐藏的聚集索引;

聚合索引和二级索引的具体结构如下:

在这里插入图片描述

可见,聚集索引叶子节点挂载的数据为主键值对应的行数据,而二级索引叶子节点挂载的数据为主键值;

根据查询字段不同可分为:

  • 若SQL查询语句中根据主键值进行数据查询,则直接从聚集索引中查询数据;

  • 若根据其它索引进行数据查询,则需要先从二级索引查找出主键值然后再通过回表查询到聚集索引中查找数据(覆盖索引除外),即回表查询

    在这里插入图片描述

4. 索引使用

4.1 单列索引和联合索引

单列索引:一个索引中只包含一个字段;

联合索引:一个索引中包含多个字段;

一条SQL查询语句中涉及到了多个单列索引的话,只会执行其中的一个索引,而其它索引都会失效,对此,若业务需要涉及多个索引查询的话建议将这几个字段共同构建成一个联合索引:

create index idx_table_a_b_c on table(a, b, c);

联合索引的多个字段的索引值都存储在一起

在这里插入图片描述

在使用联合查询时,需要遵守最左前缀法则,即sql语句中若使用到了联合索引中的字段,则该联合索引中的第一个字段必须出现,否则整个索引都会失效:

假设创建了一个联合索引如下:

create index idx_table_a_b_c on table(a, b, c);

a为联合索引中最左边的列,查询时必须存在,否则整个索引都会失效:

-- 有效索引
select * from table where a = 1 and b = 2 and c = 3-- a不存在,无效索引
select * from table where b = 2 and c = 3;-- 若中间一列被跳过,则从被跳过的那列开始后面的索引无效
select * from table where a = 1 and c = 3;-- 有效索引,与顺序无关,只要第一个列存在即可实现索引
select * from table where c = 3 and b = 2 and a = 3;

:若联合索引中出现范围查询(><)的话,则范围查询右侧的索引都会失效,对此,若业务运行建议使用<=>=

4.2 覆盖索引

若需要查询的字段在该索引中都能找到,则称为覆盖索引覆盖索引只需在二级索引中就能找到所需的数据并直接返回,无需执行回表查询,如图所示就是一个覆盖索引:

在这里插入图片描述

若需要查询的数据无法在二级索引中都找全,则需要进行回表查询:

在这里插入图片描述

像上述例子,则可以将其这几个字段共同构建成一个联合索引,则在进行数据索引时仅通过二级索引就能查找到所需的数据,避免回表查询:

create index idx_user_name_gender on user(name, gender);

4.3 前缀索引

当字段类型为字符串时,有时候需要索引很长的字符串(文本之类),这样会让索引变得很大,浪费大量磁盘IO,影响查询效率;此时可以只给字符串的一部分前缀建立索引,以此节约索引空间从而提高索引效率:

语法如下:

create index idx_table_a on table_name(column(n));

5. SQL提示

若一个字段存在多个索引(单列索引和联合索引),则在查询该字段时mysql内部会自动评估哪个执行效率更高进而使用哪个索引,可如果我们想要指定执行的索引的话,就可以使用SQL提示来让mysql执行我们指定的索引!

假设现在字段 a 有 单列索引idx_a联合索引 idx_a_b_c,我们想要它执行单列索引idx_a,语法如下:

-- use index,建议mysql使用指定索引,但也只是建议,mysql内部还会进行再次评估
select * from table use index(idx_a) where a = 1;-- ingonre index,忽略掉指定的索引
select * from table ignore index(idx_a_b_c) where a = 1;-- force index,强制使用指定索引
select * from table force index(idx_a) where a = 1;

:可以通过explain关键字(加在sql语句之前)查询当前sql执行计划判断是否有使用到索引!

6. 索引失效情况

索引会在一些特殊情况会失效:

  • 在查询中对索引列进行函数运算时,索引会失效;
  • 字符串类型的字段使用时没有加引号,索引会失效;
  • 进行模糊匹配时,使用头部模糊匹配时索引会失效(like '%三丰’ 或 like '%三%'),而尾部模糊匹配不会(like '张%');
  • 使用or连接字时,or左右两边的字段都得是索引则索引才会生效,否则只有一边是索引另一边不是索引则索引会失效;
  • MySQL会对全表查询和索引查询的查询效率进行评估,若发现索引查询效率慢于全表查询则不会使用索引;

以上便是对MySQL 索引的介绍与使用了,如果上述内容对大家有帮助的话请给一个三连关注吧💕( •̀ ω •́ )✧✨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/10888.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JVM方法区

一、栈、堆、方法区的交互关系 二、方法区的理解: 尽管所有的方法区在逻辑上属于堆的一部分&#xff0c;但是一些简单的实现可能不会去进行垃圾收集或者进行压缩&#xff0c;方法区可以看作是一块独立于Java堆的内存空间。 方法区(Method Area)与Java堆一样&#xff0c;是各个…

STM32 TIM定时器配置

TIM简介 TIM&#xff08;Timer&#xff09;定时器 定时器可以对输入的时钟进行计数&#xff0c;并在计数值达到设定值时触发中断 16位计数器、预分频器、自动重装寄存器的时基单元&#xff0c;在72MHz计数时钟下可以实现最大59.65s的定时 不仅具备基本的定时中断功能&#xff…

自定义数据集 使用pytorch框架实现逻辑回归并保存模型,然后保存模型后再加载模型进行预测,对预测结果计算精确度和召回率及F1分数

import numpy as np import torch import torch.nn as nn import torch.optim as optim from sklearn.metrics import precision_score, recall_score, f1_score# 数据准备 class1_points np.array([[1.9, 1.2],[1.5, 2.1],[1.9, 0.5],[1.5, 0.9],[0.9, 1.2],[1.1, 1.7],[1.4,…

< OS 有关 > 阿里云 几个小时前 使用密钥替换 SSH 密码认证后, 发现主机正在被“攻击” 分析与应对

信息来源&#xff1a; 文件&#xff1a;/var/log/auth.log 因为在 sshd_config 配置文件中&#xff0c;已经定义 LogLevel INFO 部分内容&#xff1a; 2025-01-27T18:18:55.68272708:00 jpn sshd[15891]: Received disconnect from 45.194.37.171 port 58954:11: Bye Bye […

[创业之路-270]:《向流程设计要效率》-2-企业流程架构模式 POS架构(规划、业务运营、支撑)、OES架构(业务运营、使能、支撑)

目录 一、POS架构 二、OES架构 三、POS架构与OES架构的差异 四、各自的典型示例 POS架构典型示例 OES架构典型示例 示例分析 五、各自的典型企业 POS架构典型企业 OES架构典型企业 分析 六、各自典型的流程 POS架构的典型流程 OES架构的典型流程 企业流程架构模式…

【贪心算法篇】:“贪心”之旅--算法练习题中的智慧与策略(一)

✨感谢您阅读本篇文章&#xff0c;文章内容是个人学习笔记的整理&#xff0c;如果哪里有误的话还请您指正噢✨ ✨ 个人主页&#xff1a;余辉zmh–CSDN博客 ✨ 文章所属专栏&#xff1a;贪心算法篇–CSDN博客 文章目录 一.贪心算法1.什么是贪心算法2.贪心算法的特点 二.例题1.柠…

Python 梯度下降法(二):RMSProp Optimize

文章目录 Python 梯度下降法&#xff08;二&#xff09;&#xff1a;RMSProp Optimize一、数学原理1.1 介绍1.2 公式 二、代码实现2.1 函数代码2.2 总代码 三、代码优化3.1 存在问题3.2 收敛判断3.3 函数代码3.4 总代码 四、优缺点4.1 优点4.2 缺点 五、相关链接 Python 梯度下…

【2025年更新】1000个大数据/人工智能毕设选题推荐

文章目录 前言大数据/人工智能毕设选题&#xff1a;后记 前言 正值毕业季我看到很多同学都在为自己的毕业设计发愁 Maynor在网上搜集了1000个大数据的毕设选题&#xff0c;希望对大家有帮助&#xff5e; 适合大数据毕业设计的项目&#xff0c;完全可以作为本科生当前较新的毕…

three.js+WebGL踩坑经验合集(6.2):负缩放,负定矩阵和行列式的关系(3D版本)

本篇将紧接上篇的2D版本对3D版的负缩放矩阵进行解读。 (6.1):负缩放&#xff0c;负定矩阵和行列式的关系&#xff08;2D版本&#xff09; 既然three.js对3D版的负缩放也使用行列式进行判断&#xff0c;那么&#xff0c;2D版的结论用到3D上其实是没毛病的&#xff0c;THREE.Li…

反向代理模块jmh

1 概念 1.1 反向代理概念 反向代理是指以代理服务器来接收客户端的请求&#xff0c;然后将请求转发给内部网络上的服务器&#xff0c;将从服务器上得到的结果返回给客户端&#xff0c;此时代理服务器对外表现为一个反向代理服务器。 对于客户端来说&#xff0c;反向代理就相当…

软件工程经济学-日常作业+大作业

目录 一、作业1 作业内容 解答 二、作业2 作业内容 解答 三、作业3 作业内容 解答 四、大作业 作业内容 解答 1.建立层次结构模型 (1)目标层 (2)准则层 (3)方案层 2.构造判断矩阵 (1)准则层判断矩阵 (2)方案层判断矩阵 3.层次单排序及其一致性检验 代码 …

【回溯】目标和 字母大小全排列

文章目录 494. 目标和解题思路&#xff1a;回溯784. 字母大小写全排列解题思路&#xff1a;回溯 494. 目标和 494. 目标和 给你一个非负整数数组 nums 和一个整数 target 。 向数组中的每个整数前添加 或 - &#xff0c;然后串联起所有整数&#xff0c;可以构造一个 表达式…

告别复杂,拥抱简洁:用plusDays(7)代替plus(7, ChronoUnit.DAYS)

前言 你知道吗?有时候代码里的一些小细节看起来很简单,却可能成为你调试时的大麻烦。在 Java 中,我们用 LocalDateTime 进行日期和时间的操作时,发现一个小小的替代方法可以让代码更简洁,功能更强大。这不,今天我们就来探讨如何用 LocalDateTime.now().plusDays(7) 替代…

《苍穹外卖》项目学习记录-Day10订单状态定时处理

利用Cron表达式生成器生成Cron表达式 1.处理超时订单 查询订单表把超时的订单查询出来&#xff0c;也就是订单的状态为待付款&#xff0c;下单的时间已经超过了15分钟。 //select * from orders where status ? and order_time < (当前时间 - 15分钟) 遍历集合把数据库…

【深度分析】微软全球裁员计划不影响印度地区,将继续增加当地就业机会

当微软的裁员刀锋掠过全球办公室时&#xff0c;班加罗尔的键盘声却愈发密集——这场资本迁徙背后&#xff0c;藏着数字殖民时代最锋利的生存法则。 表面是跨国公司的区域战略调整&#xff0c;实则是全球人才市场的地壳运动。微软一边在硅谷裁撤年薪20万美金的高级工程师&#x…

Linux中 端口被占用如何解决

lsof命令查找 查找被占用端口 lsof -i :端口号 #示例 lsof -i :8080 lsof -i :3306 netstat命令查找 查找被占用端口 netstat -tuln | grep 端口号 #示例 netstat -tuln | grep 3306 netstat -tuln | grep 6379 ss命令查找 查找被占用端口 ss -tunlp | grep 端口号 #示例…

qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记

qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记 文章目录 qt-Quick3D笔记之官方例程Runtimeloader Example运行笔记1.例程运行效果2.例程缩略图3.项目文件列表4.main.qml5.main.cpp6.CMakeLists.txt 1.例程运行效果 运行该项目需要自己准备一个模型文件 2.例程缩略图…

高性能消息队列Disruptor

定义一个事件模型 之后创建一个java类来使用这个数据模型。 /* <h1>事件模型工程类&#xff0c;用于生产事件消息</h1> */ no usages public class EventMessageFactory implements EventFactory<EventMessage> { Overridepublic EventMessage newInstance(…

Spring Boot项目如何使用MyBatis实现分页查询

写在前面&#xff1a;大家好&#xff01;我是晴空๓。如果博客中有不足或者的错误的地方欢迎在评论区或者私信我指正&#xff0c;感谢大家的不吝赐教。我的唯一博客更新地址是&#xff1a;https://ac-fun.blog.csdn.net/。非常感谢大家的支持。一起加油&#xff0c;冲鸭&#x…

【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】1.27 线性代数王国:矩阵分解实战指南

1.27 线性代数王国&#xff1a;矩阵分解实战指南 #mermaid-svg-JWrp2JAP9qkdS2A7 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-JWrp2JAP9qkdS2A7 .error-icon{fill:#552222;}#mermaid-svg-JWrp2JAP9qkdS2A7 .erro…