详细介绍MySQL的索引(下)

news2025/1/11 2:00:12

索引的使用

同一条数据在未创建索引的情况下耗时:

nick字段是未创建索引的

 select * from t_user WHERE nick = '邹丽';
 SHOW PROFILES;

耗时为:

user_account字段创建了唯一索引
 

 select * from t_user WHERE user_account = '13781945844';
 SHOW PROFILES;

查询耗时为:

当然以上的对比仍然是在表数据量较小的情况下,当表的数据量逐渐增多,创建索引的数据查询耗时是要远低于未创建索引的耗时。

索引失效 

如果索引了多列(联合索引),要遵守最左前缀法则。最左前缀法则指的是查询从索引的最左列开始,并且不跳过索引中的列。如果跳过了某一列,索引将部分失效(后面的字段索引失效)。

展示如下:

查看该表索引

show index FROM t_user;

可以看到为nick, authority,score这三个字段创建了联合索引,且创建顺序为nick,authority额,score。

按照索引正常查询
SELECT * from t_user WHERE nick = 'PIS' and authority = '1' and score = '11'

查看结果

查看索引覆盖情况

EXPLAIN SELECT * from t_user WHERE nick = 'PIS' and authority = '1' and score = '11';

观察可以发现,这里的索引并未失效。

当我们修改查询条件

EXPLAIN SELECT * from t_user WHERE nick = 'PIS' and authority = '1';

结果如下:

可以发现索引仍未失效。

当我们修改查询顺序

EXPLAIN SELECT * from t_user WHERE authority = '1' and score = '11' and nick = 'PIS';

 

MySQL会进行查询优化,当最左边的索引条件出现后,但可能不符合创建索引的顺序时,MySQL会自动优化查询,将查询条件重新组合。 

最左前缀法则
EXPLAIN SELECT * from t_user WHERE nick = 'PIS' and score = '11';

可以看到score索引发生了失效,这是因为没有符合最左前缀法则。

再举一个例子

EXPLAIN SELECT * from t_user WHERE authority = '1' and score = '11';

这里可以看到,索引全部都失效了。

范围查询

联合索引中,出现范围查询(>,<),范围查询右侧的列索引失效。

这里将authority字段类型改成int类型做测试
 

EXPLAIN SELECT * from t_user WHERE nick = 'PIS' and authority > 3 and score = '11';

 在业务允许的范围下,我们要进行范围查询最好带上等于号,比如>= 或者 <= 


EXPLAIN SELECT * from t_user WHERE nick = 'PIS' and authority >= 3 and score = '11';

 可以看到这样索引未失效。 

索引列运算

不要在索引列上进行运算操作,索引将失效。

查看索引情况

我们用user_account这个字段的唯一索引展示
正常未失效的情况如下:

explain SELECT * from t_user WHERE user_account = '17630150099';

 

在索引列上进行运算(包括函数运算)导致索引失效的情况如下:

explain SELECT * from t_user WHERE SUBSTRING(user_account,10,2) = '99';

 观察可知,索引发生了失效。

字符串不加引号

字符串类型字段使用时,不加引号,索引将失效。

explain SELECT * from t_user WHERE user_account = 17630150099;

可以发现,在唯一索引user_account中查询的时候未加引号,可以导致索引失效。

模糊查询

如果仅仅是尾部模糊匹配,索引不会失效。如果是头部模糊匹配,索引失效。

索引失效例子:

explain SELECT * from t_user WHERE nick LIKE '%I';

索引未失效例子:

explain SELECT * from t_user WHERE nick LIKE 'I%';

 

 OR连接的条件

用or分割开的条件,如果or前的条件中的列有索引,而后面的列中没有索引,那么涉及的索引都不会被用到。

 数据分布影响

如果MySQL评估使用索引比全表更慢,则不使用索引。

 SQL提示

SQL提示,是优化数据库的一个重要手段,简单来说,就是在SQL语句中加入一些人为的提示来达到优化操作的目的。

user index: 告知数据库要用哪个索引。

SELECT * from t_user USE INDEX(user_index) WHERE user_account = '17630151111';

ignore index: 告知数据库忽略哪个索引。

SELECT * from t_user IGNORE INDEX(user_index) WHERE user_account = '17630151111';

force index:  强制数据库必须用某个索引。

SELECT * from t_user FORCE INDEX(user_index) WHERE user_account = '17630151111';

覆盖索引

尽量使用覆盖索引(查询使用了索引,并且需要返回的列,在该索引中色经全部能够找到),减少select *。

因为如果在查询的字段中出现了非索引的字段,那么将会发生回表查询,即查询了两次,性能相对于查询一次的较差。

在explain执行计划中有一列是Extra


using index condition/ Null :查找使用了索引,但是需要回表查询数据。

using where; using index : 查找使用了索引,但是需要的数据都在索引列中能找到一所以不需要回表查询数据。

 前缀索引

当字段类型为字符串(varchar , text等),时,有时候需要索引很长的字符串,这会让索引变得很大,查询时,浪费大量的磁盘IO,影响查询效率。此时可以只将字符串的一部分前缀抽取出来,建立索引,这样可以大大节约索引空间,从而提高索引效率。

创建前缀索引的语法

如下:

create index id_xxx on table_name(column(n))

column(n) 代表我要截取某个字段的钱n个字符来创建索引。

前缀索引的长度 

可以根据索引的选择性来决定,而选择性是指不重复的索引值(基数)和数据表的记录总数的比值,索引选择性越高则查询效率越高,唯一索引的选择性是1,这是最好的索引选择性,性能也是最好的。

计算公式 :

select count (distinct substring(column,x,y))/count(*) from table;

 算出来的值越趋近于一说明性能也是越好的,但是当y远大于x时,索引的存储空间也是一个需要考虑的问题。因此要根据实际的业务来选择。

单列索引&联合索引

单列索引:即一个索引只包含单个列。

联合索引:即一个索引包含了多个列。

在业务场景中,如果存在多个查询条件,考虑针对于查询字段建立索引时,建议建立联合索引,而非单列索引。

多条件联合查询时,MySOL优化器会评估哪个字段的索引效率更高,会选择该索引完成本次查询。

适当的覆盖索引使用可以避免回表查询,从而提升查询性能。

索引设计的原则

1.针对于数据量较大(超过一百多万),且查询比较频繁的表建立索引。

2.针对于常作为查询条件(where)、排序(order by)、分组(group by)操作的字段建立索引。

3.尽量选择区分度高的列作为索引,尽量建立唯一索引,区分度越高,使用索引的效率越高。

4.如果是字符串类型的字段,字段的长度较长,可以针对于字段的特点,建立前缀索引。

5.尽量使用联合索引,减少单列索引,查询时,联合索引很多时候可以覆盖索引,节省存储空间,避免回表,提高查询效率。

6.要控制索引的数量,索引并不是多多益善,索引越多,维护索引结构的代价也就越大,会影响增删改的效率。

7. 如果索引列不能存储NULL值,请在创建表时使用NOT NULL约束它。当优化器知道每列是否包含NULL值时,它可以更好地确定哪个索引最有效地用于查询。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

重温react-06(初识函数组件和快速生成格式的插件使用方式)

开始 函数组件必然成为未来发展的趋势(个人见解),总之努力的去学习,才能赚更多的钱.加油呀! 函数组件的格式 import React from reactexport default function LearnFunction01() {return (<div>LearnFunction01</div>) }以上是函数式组件的组基本的方式 快捷生…

前端优化:首屏加载速度的实践

目录 目录 前言 多图片的懒加载 避免用户多次点击请求 骨架屏原理 结束语 前言 随着互联网技术的飞速发展&#xff0c;前端网页逐渐取代了传统客户端成为用户获取信息、进行交互的重要渠道&#xff0c;但是网页也有常见的弊端&#xff0c;比如网页首屏加载速度的快慢直接…

大模型压缩量化方案怎么选?无问芯穹Qllm-Eval量化方案全面评估:多模型、多参数、多维度

基于 Transformer架构的大型语言模型在各种基准测试中展现出优异性能&#xff0c;但数百亿、千亿乃至万亿量级的参数规模会带来高昂的服务成本。例如GPT-3有1750亿参数&#xff0c;采用FP16存储&#xff0c;模型大小约为350GB&#xff0c;而即使是英伟达最新的B200 GPU 内存也只…

5G NR PUSCH物理层过程

物理层过程 加扰 假设要在单个码字q上传输的bit块为 b ( q ) ( 0 ) , . . . , b ( q ) ( M b i t ( q ) − 1 ) b^{(q)}(0),...,b^{(q)}(M_{bit}^{(q)} - 1) b(q)(0),...,b(q)(Mbit(q)​−1) &#xff0c;其中 M b i t ( q ) M_{bit}^{(q)} Mbit(q)​是总比特数&#xff0c;加…

MySQL高级-MVCC-隐藏字段

文章目录 1、介绍2、测试2.1、进入服务器中的 /var/lib/mysql/atguigu/2.2、查看有主键的表 stu2.3、查看没有主键的表 employee2.3.1、创建表 employee2.3.2、查看表结构及其其中的字段信息 1、介绍 ---------------- | id | age | name | ---------------- | 1 | 1 | Js…

云计算与 AI 融合:Amazon Connect 开创客户服务智能时代

在亚马逊云科技 re:Invent 2023 大会上&#xff0c;Amazon Connect 引入生成式人工智能功能&#xff0c;标志着客户服务迎来了智能化的新时代。云计算作为提供弹性、可靠、高效服务的基础&#xff0c;与人工智能的融合为客户服务注入了新的活力。这次推出的新功能不仅仅是技术的…

Python和MATLAB粘性力接触力动态模型半隐式欧拉算法

&#x1f3af;要点 &#x1f3af;运动力模型计算制作过程&#xff1a;&#x1f58a;相机捕捉网球运动图&#xff0c;制定运动数学模型&#xff0c;数值微分运动方程 | &#x1f58a;计算运动&#xff0c;欧拉算法离散积分运动&#xff0c;欧拉-克罗默算法微分运动方程 &#…

神经网络实战2-损失函数和反向传播

其实就是通过求偏导的方式&#xff0c;求出各个权重大小 loss函数是找最小值的&#xff0c;要求导&#xff0c;在计算机里面计算导数是倒着来的&#xff0c;所以叫反向传播。 import torch from torch.nn import L1Lossinputstorch.tensor([1,2,3],dtypetorch.float32) targe…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 灰度图像恢复(100分) - 三语言AC题解(Python/Java/Cpp)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; &#x1f…

Android 根证书管理与证书验证

大部分的安卓应用都免不了与后端服务器进行通信。在通信过程中&#xff0c;主要面临两方面的风险&#xff1a;1、中间人攻击。当通信使用 HTTP 等明文协议&#xff0c;通信内容可被嗅探甚至篡改。2、通信内容被攻击者分析。使用加密的协议&#xff0c;虽然避免了中间人攻击&…

RocketMQ 顺序消息和事务消息及其原理

RocketMQ 顺序消息和事务消息 1、Spring Cloud Alibaba RocketMq 架构图2、RocketMQ 顺序消息2.1、RockerMQ 实现顺序消费2.1.1、顺序发消息2.1.2、顺序收消息 2.2、顺序发送的技术原理2.3、顺序消费的技术原理 3、RocketMQ 的事务消息3.1、RocketMQ 事务消息流程3.2、事务消息…

查看Windows启动时长

&#xff08;附图片&#xff09;电脑自带检测开机时长---查看方式_电脑开机时长命令-CSDN博客 eventvwr - Windows日志 - 系统 - 查找 - 6013.jpg

如何借助 LLM 设计和实现任务型对话 Agent

1 引言 在人工智能的快速发展中&#xff0c;任务型对话 Agent 正成为提升用户体验和工作效率的关键技术。这类系统通过自然语言交互&#xff0c;专注于高效执行特定任务&#xff0c;如预订酒店或查询天气。尽管市场上的开源框架如 Rasa 和 Microsoft Bot Framework 在对话理解…

使用ioDraw,AI绘图只需几秒钟!

只需几秒钟&#xff0c;就能将文字或图片转化为精准的思维导图、流程图、折线图、柱状图、饼图等各种图表&#xff01; 思维导图 思维导图工具使用入口 文字转思维导图 将文本大纲或想法转换成可视化的思维导图&#xff0c;以组织和结构化您的想法。 图片转思维导图 从现有…

汽车电子工程师入门系列——AUTOSAR通信服务框架(下)

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明自己,无利益不试图说服别人,是精神上的节…

垃圾回收与算法

目录 一、判断对象已经 "死亡" 1、引用计数法 2、可达性分析 二、垃圾收集算法 1、标记清楚算法 2、复制算法 3、标记整理算法 4、分代收集算法 4.1、新生代与复制算法 4.2老年代与标记复制算法 一、判断对象已经 "死亡" 1、引用计数法 在 Java 中&#…

基于STM32的温湿度检测TFT屏幕proteus恒温控制仿真系统

一、引言 本文介绍了一个基于STM32的恒温控制箱检测系统&#xff0c;该系统通过DHT11温湿度传感器采集环境中的温湿度数据&#xff0c;并利用TFT LCD屏幕进行实时显示。通过按键切换页面显示&#xff0c;通过按键切换实现恒温控制箱的恒温控制。为了验证系统的可靠性和稳定性&…

低代码表单配置平台替代普通表单配置平台,前端部分重构的设计和思路

前言 最近将公司的旧表单配置平台重构为低代码表单配置平台&#xff0c;这里记录一下这个过程的设计和思路&#xff0c;不涉及具体的代码&#xff1b;另外这篇文章基本只涉及前端部分&#xff0c;也不涉及与后端数据交互部分。 需求 固化的表单配置平台 -> 灵活的表单配置…

python格式文件

python小白考后复习 CSV格式文件ini格式文件我们可以读取所有节点还可以输出一个节点下所有键值对组成的元组获取节点下的键对应的值判断节点是否存在添加节点还可以添加键值还可以删除节点 XML格式文件读取若是文件格式存在的xml若是以字符串形式存在的xml获取子标签还有获取子…

【最长公共前缀 动态规划】2430. 对字母串可执行的最大删除数

如果有不明白的&#xff0c;请加文末QQ群。 本文涉及知识点 最长公共前缀 动态规划 动态规划汇总 LeetCode 2430. 对字母串可执行的最大删除数 给你一个仅由小写英文字母组成的字符串 s 。在一步操作中&#xff0c;你可以&#xff1a; 删除 整个字符串 s &#xff0c;或者 …