我的编程空间,编程开发者的网络收藏夹
学习永远不晚

mysql中什么情况会导致索引失效

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

mysql中什么情况会导致索引失效

这篇文章主要为大家展示了“mysql中什么情况会导致索引失效”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql中什么情况会导致索引失效”这篇文章吧。


为了讲解以下索引内容,我们先建立一个临时的表 test02

CREATE TABLE `sys_user` (  `id` varchar(64) NOT NULL COMMENT '主键',  `name` varchar(64) DEFAULT NULL COMMENT '名字',  `age` int(64) DEFAULT NULL COMMENT '年龄',  `pos` varchar(64) DEFAULT NULL COMMENT '职位',  PRIMARY KEY (`id`),  KEY `idx_sys_user_nameAgePos` (`name`,`age`,`pos`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表';

这个表有四个字段 主键 、名字、年龄、职位

下面我们来讲解第一个口诀:
1.全值匹配我最爱
2.最佳左前缀法则(重要)

全值匹配意思就是联立的复合索引的顺序和个数要和检索的条件顺序和个数相同。
最佳左前缀法则是指,如果索引了多列,要遵守最左前缀法则。指的是查询从索引的最左前列开始并且不跳过索引中的列
下面我们给这个表建立一个复合索引

ALTER TABLE sys_user ADD INDEX idx_sys_user_nameAgePos(name,age,pos);

以下是我们的检索语句:

SELECT * FROM sys_user WHERE name='小明' AND age = 22 AND pos ='java';

mysql中什么情况会导致索引失效

我们通过在检索语句前面加关键字 EXLAIN,可以知道是否使用的索引

(1)EXPLAIN SELECT * FROM sys_user WHERE name='小明' AND age = 22 AND pos ='java';(2)EXPLAIN SELECT * FROM sys_user WHERE name='小明' AND age = 22 ;(3)EXPLAIN SELECT * FROM sys_user WHERE name='小明'  AND pos ='java';

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

通过展示的结果我们可以知道,第一个复合索引的三个字段我们都用了,第二个复合索引我们只用到两个字段,第三个复合索引我们只用到一个字段。三个语句我们都用到索引,显然第一种是最优的。

我们再看看哪种情况会失效:

(4)EXPLAIN SELECT * FROM sys_user WHERE age = 22;(5)EXPLAIN SELECT * FROM sys_user WHERE pos ='java';(6)EXPLAIN SELECT * FROM sys_user WHERE age = 22 AND pos ='java';

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

以上三种情况都变成了全表扫描,原因是违反了最左左前缀原则,因为复合索引最左边的是name,当检索条件name没在前面索引将失效,第一种情况满足了全值匹配,第二种满足了两个字段name和age,第三种因为只满足了name,所以索引只用到name。

3.不在索引列上做任何操作(计算、函数(自动或手动)类型转换),会使索引失效转为全表扫描

(7)EXPLAIN SELECT * FROM sys_user WHERE  LEFT(name,1)='小明';

mysql中什么情况会导致索引失效

第七种情况失效是因为索引列做了计算或者函数的操作,导致了全表扫描。

4.存储引擎不能使用索引中范围条件右边的列
可能大家关看上面的文字不知道是什么意思,下面我们执行一下查询语句就清楚了

(8)EXPLAIN SELECT * FROM sys_user WHERE name='小明' AND age < 22 AND pos ='java';

mysql中什么情况会导致索引失效

从上图我们可以知道type变成了范围级别,也就是说age<22之后的pos字段的索引失效了。

5.尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致),减少select * 的使用
这个就是字面意思,查询具体的字段比查询*效率更高,下面我们坐一下对比

(9)EXPLAIN SELECT * FROM sys_user WHERE name='小明' AND age =22 AND pos ='java';(10)EXPLAIN SELECT name,age,pos FROM sys_user WHERE name='小明' AND age =22 AND pos ='java';

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

6.mysql在使用不等于(!= 或者<>)的时候无法使用索引会导致全表扫描
(!= 或者<>)通常会匹配到大量数据,当使用索引的花销大于全表扫描时,mysql则会放弃使用索引而选择全表扫描

(11)EXPLAIN SELECT * FROM sys_user WHERE name !='小明'

mysql中什么情况会导致索引失效

结果显示索引失效导致了全表扫描

7.is null,is not null 也无法使用索引
is null,is not null 通常会匹配到大量数据,当使用索引的花销大于全表扫描时,mysql则会放弃使用索引而选择全表扫描

(12)EXPLAIN SELECT * FROM sys_user WHERE name is not null

mysql中什么情况会导致索引失效

8.like以通配符开头('%abc…')mysql索引会失效变成全表扫描的操作,(%写右边则可以避免索引失效,如果业务实在需要'%abc…%'则可以用覆盖索引避免索引失效)

(13)EXPLAIN SELECT * FROM sys_user WHERE name like '%明%'(14)EXPLAIN SELECT * FROM sys_user WHERE name like '明%'(15)EXPLAIN SELECT name,age,pos FROM sys_user WHERE name like '%明%'

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

mysql中什么情况会导致索引失效

从上面的结果,第一种索引失效,第二种只写右边的%则可以避免索引失效,第三种如果业务实在需要‘%abc…%'这种sql,则可以用覆盖索引解决索引失效的问题

9.字符串不加单引号索引会失效

(16)EXPLAIN SELECT * FROM sys_user WHERE name=222;

mysql中什么情况会导致索引失效

因为检索字符串是必须加单引号,上面用用了222是int类型,mysql在检索的时候会判断name是varchar的类型会将222转换为'222'进行检索,索引列发生了类型转换,故索引失效。

10.少用or,用它连接时会索引失效

(16)EXPLAIN SELECT * FROM sys_user WHERE name='小明' or age = 22;

mysql中什么情况会导致索引失效

以上是“mysql中什么情况会导致索引失效”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

mysql中什么情况会导致索引失效

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中什么情况会导致索引失效

这篇文章主要为大家展示了“mysql中什么情况会导致索引失效”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql中什么情况会导致索引失效”这篇文章吧。为了讲解以下索引内容,我们先建立一个临时
2023-06-25

情况导致MySQL索引失效

MySQL索引失效的几种情况及代码示例引言:在MySQL数据库中,索引是提高查询性能的重要因素之一。然而,有时候我们会发现索引并没有起到预期的作用,查询性能并没有得到提升,甚至还会导致查询变得更慢。究其原因,很可能是索引失效了。本文将介绍
情况导致MySQL索引失效
2024-02-22

MySQL导致索引失效的几种情况

目录一、准备工作二、索引失效规则1.优先使用联合索引2.最左匹配原则3.范围条件右边的列索引失效4.计算、函数导致索引失效5.类型转换导致索引失效6.不等于(!= 或者)索引失效7.is null可以使用索引,is not null无法
2022-06-23

mysql索引什么情况下会失效

mysql索引在不使用索引列进行查询、数据类型不匹配、前缀索引的使用不当、使用函数或表达式进行查询、索引列的顺序不正确、数据更新频繁和索引过多或过少情况下会失效。1、不使用索引列进行查询,为了避免这种情况,应该在查询中使用适当的索引列;2、
2023-08-09

MySQL导致索引失效的情况有哪些

本篇内容主要讲解“MySQL导致索引失效的情况有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL导致索引失效的情况有哪些”吧!一、准备工作首先准备两张表用于演示:CREATE TAB
2023-07-02

Mysql索引失效的情况

前提:建立了一个employee表,同时建立了一个组合索引lastName,gender 。 1.最常说的like匹配                            例1 explain select * from employee where las
Mysql索引失效的情况
2016-01-15

会导致索引失效语句

1、使用like关键字模糊查询时,% 放在前面索引不起作用,只有“%”不在第一个位置,索引才会生效(like ‘%文’–索引不起作用)2、使用联合索引时,只有查询条件中使用了这些字段中的第一个字段,索引才会生效3、使用OR关键字的查询,查询语句的查询条件中只有
2014-09-21

mysql索引失效的几种情况

常见情况:1、使用函数或运算;2、隐式类型转换;3、使用不等于(!=或);4、使用like操作符,并以通配符开头;5、or条件;6、null值;7、索引选择性低;8、复合索引的最左前缀原则;9、优化器决策;10、force index和ig
mysql索引失效的几种情况
2024-02-22

Mysql索引查询失效的情况

一:不在索引上使用函数,计算等 在kq_time上增加了一个索引,见图一 我们使用date()函数进行查询,见图二 图二根据kq_time字段查询并没有使用索引,我们可以根据kq_time换一种写法,他就可以走索引了,见图三 查询条件是一样的,图三的写法
Mysql索引查询失效的情况
2021-05-22

MySQL索引失效的情况有哪些

这篇文章主要讲解了“MySQL索引失效的情况有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL索引失效的情况有哪些”吧!1.最左前缀原则在MySQL数据库中,联合索引遵守最左前缀
2023-07-05

mysql引发索引失效的情况有哪些

这篇文章主要讲解了“mysql引发索引失效的情况有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql引发索引失效的情况有哪些”吧!1、在查询条件中计算索引列的使用函数或操作。若已建
2023-06-20

MySQL索引失效的几种情况小结

目android录1.最左前缀原则2. 计算、函数使索引失效3. 类型转换导致索引失效4. 不等于(或!=)导致索引失效5. is not null /is null可能不走索引,也可以走索引6. 模糊匹配Like以%开头7. OR前后
2023-03-20

Java中什么情况会导致内存泄漏

这篇文章主要讲解了“Java中什么情况会导致内存泄漏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中什么情况会导致内存泄漏”吧!概念内存泄露:指程序中动态分配内存给一些临时对象,但对
2023-06-16

编程热搜

目录