导致mysql索引失效的原因有哪些

article/2025/9/30 0:46:02

MySQL五种索引类型

sql执行顺序

(根据sql执行顺序来优化,可以把关联表判断条件放到on后面)
from  
on  
join  
where  
group by  
having  
select  
distinct  
union  
order by   
limit

一、哪些字段适合建索引

在这里插入图片描述

二、范围查询索引失效问题

范围查询索引失效,只针对二级索引(除了主键,其他索引都是二级索引)
(1)、如果走二级索引查询,步骤就是:二级索引–>主键索引–>数据,这就是回表查询(mysql索引中关联的主键,而不是数据,所以二级索引查询会有一个回表的操作)。
(2)、硬盘随机I/O的性能远低于顺序I/O。

1、范围查询失效问题

注意,放弃索引走全表查询需要满足以下几点:
1、二级索引
2、范围查询
3、查询数量超过了总数据的某个百分比
4、并且查询字段不止id和索引还包含了其他字段(select后面字段不仅仅为id和where后端索引字段)

  • 主键一定走索引
  • 其他范围查询 >, >=, <, <=, like, !=, <>, is null, is not null虽然可以走索引,但是当查询数量超过了总数据的某个百分比,并且为二级索引,并且查询字段不止id和索引还包含了其他字段也会走全表查询,因为mysql的sql优化器会认为回表查询的随机I/O代价大于顺序I/O全表扫的情况下,将放弃走索引。
    如下这个sql是不走索引的,并且查询时间为7.337s,数据量为3557003
    在这里插入图片描述
    在这里插入图片描述
    如果我们强制他走索引,这时候去执行sql时,查询时间用了39.680s,数据量依然为3557003
    在这里插入图片描述
    在这里插入图片描述
    由上可见这里不用索引查询更快,因为通过索引查询会有一个回表操作

建议索引 select * from 表名 use index(索引名) where …
强制索引 select * from 表名 force index(索引名) where …
忽略索引 select * from 表名 ignore index(索引名) where …

2、左前缀原则

  • 使用联合索引(id,name,age)查询数据,判断条件需遵循最左原则

3、函数导致索引失效

  • SELECT * FROM user WHERE DATE(create_time) = ‘2020-09-03’;
    create_time字段设置索引,那就无法使用函数,否则索引失效,因为函数会破坏索引有序性,sql优化器会放弃走索引。

4、字段类型不一致索引失效

  • SELECT * FROM user WHERE height= 175;
    height为varchar类型导致索引失效,尤其多张表时注意。

5、运算符导致索引失效

  • 如果你对列进行了(+,-,*,/,!), 那么都将不会走索引。

    SELECT * FROM user WHERE age - 1 = 20;

6、or引起索引失效

  • or两边必须都是索引,否则用or连接的左右语句会索引失效

例:(counter1 和 counter2是索引,counter5不是索引字段)

在这里插入图片描述在这里插入图片描述

7、模糊查询导致索引失效

  • SELECT * FROM user WHERE name LIKE ‘%冰’;
    模糊搜索如果你前缀也进行模糊搜索,那么不会走索引。

8、IN、NOT IN、 EXISTS、NOT EXISTS导致索引失效

  • 和模糊查询类似,当数据量超过某个百分比后会放弃索引,通常情况下在这些条件查询的数据量不大还是会走索引的 在这里插入图片描述在这里插入图片描述
  • NOT IN 和 NOT EXISTS 区别,not in会过滤掉null的数据,而exists不会,所以在用not in时要注意

在这里插入图片描述
在这里插入图片描述

注意:
exists 只检查存在性,出现多个一样的他只匹配一次
in 后面出现多个一样的他是会每个匹配一次
所以,可以的话尽量用exists

网上说的大表套小表用in,小表套大表用exists,因为exists后面会关联查询多次,经验证不存在这种问题情况,从下面执行计划中可以看出是先执行 SELECT 1 from om_obd_unbinding c WHERE required_order_code = 'OBD202210311122456538422' 因为这个sql查询的数据量刚好是1,然后在结果集的临时表中去获取最终结果。 这种情况用in或是exists都一样效果,区别无非是我上面说的相同数据匹配一次或多次区别!
在这里插入图片描述
在这里插入图片描述

9、IS NULL,IS NOT NULL索引失效问题

  • is null 会走索引,跟数据量没关系,猜想跟等值符号一个逻辑
  • is not null 跟返回数据量有关,返回数据量少则走索引,大于总数据某个百分比不走索引

在这里插入图片描述
在这里插入图片描述

10、子查询引起索引失效

子查询有三种方式:
1、跟在select后面,会很慢(不建议)
2、跟在join 后面,会创建临时表
3、跟在 where 和 on后面

当WHERE后面跟子查询,

  • 用等号连接子查询会走索引

在这里插入图片描述

  • 用 in 连接子查询不会走索引

在这里插入图片描述

11、sql优化方案

可以根据以上导致索引失效、以及sql执行顺序来针对sql进行优化


http://chatgpt.dhexx.cn/article/ESO9uuFH.shtml

相关文章

MySQL 索引失效的几种情况

前言 MySQL 中提升性能的一个最有效的方式是对数据表设计合理的索引。索引提供了高效访问数据的方法&#xff0c;并加快查询的速度&#xff0c;因此索引对查询的速度有着至关重要的影响。 使用索引可以快速定位表中的某条记录&#xff0c;从而提高数据库的查询的速度&#xf…

MySQL索引失效的9种情况(针对InnoDB存储引擎)

前言 MySQL中提高查询性能的最有效的方式之一就是对数据表合理的设计索引&#xff0c;优秀的索引的设计方案很大程度上可以提高查询的性能。 因此&#xff0c;索引对查询的速度有着至关重要的影响。 为了尽量的使优化器用到我们的索引方案&#xff0c;我们要尽量避免一些导致…

Mysql:索引失效的几种可能原因

最近闲来无事&#xff0c;发现自己mysql的知识点忘得差不多了&#xff0c;打算重新拾起来捯饬捯饬&#xff0c;个人觉得其中最重要的知识点还是mysql的优化问题&#xff0c;毕竟mysql使用方面都是很简单的东西&#xff0c;打算从索引方面开始学习吧。 有时候我们会发现&#xf…

详解MySQL索引失效

目录 B树结构 测试数据 索引失效的情况 没有用到索引 违反左前缀原则 范围查询断索引 like需要分情况 结果数据超过半数 B树结构 索引失效的根本原因其实就是违反了B树的结构特性&#xff0c;查找的时候没办法在B树上继续走下去&#xff0c;所以首先我们来回顾一下B树…

MySQL索引失效的场景,什么情况下会造成MySQL索引失效

目录 一、准备工作&#xff0c;准备sql 二、索引是什么、使用explain关键字来解析sql使用索引情况 三、索引的使用与失效场景 1.使用全部复合索引&#xff08;索引正常使用&#xff09; 2.最佳左前缀法则 3.在索引列上做任何操作&#xff08;计算、函数、自动或手动类型转…

Mysql索引失效的总结

背景 最近生产爆出一条慢sql&#xff0c;原因是用了or和!&#xff0c;导致索引失效。于是&#xff0c;总结了索引失效的十大杂症&#xff0c;希望对大家有帮助&#xff0c;加油。 一、查询条件包含or&#xff0c;可能导致索引失效 新建一个user表&#xff0c;它有一个普通索…

Mysql索引失效的常见原因如何用好索引

本篇文章主要介绍了索引失效的常见原因和如何用好索引&#xff0c;并以案例的形式进行了说明 1 结论 1.1 索引失效的常见原因 1.2 索引失效的常见误区 1.3 索引设计的几个建议 2 准备工作 先查看我本地mysql数据库的版本: select VERSION();我这里的版本是5.5.25&#xff0…

mysql索引失效情况

1、最佳左前缀原则——如果索引了多列&#xff0c;要遵守最左前缀原则。指的是查询要从索引的最左前列开始并且不跳过索引中的列。 前提条件&#xff1a;表中已添加复合索引&#xff08;username,password,age&#xff09; 分析&#xff1a;该查询缺少username&#xff0c;查询…

MySQL中索引失效有哪些?

前言 在学习MySQL时&#xff0c;如果我们想提高一条语句查询速度&#xff0c;通常都会想对字段建立索引。 但是索引并不是万能的。建立了索引&#xff0c;并不意味着任何查询语句都能走索引扫描。 稍不注意&#xff0c;可能你写的查询语句会导致索引失效&#xff0c;从而走了…

MySQL之索引失效情况

文章目录 1 MySQL索引1.1 简介1.1.1 索引基础 1.2 SQL优化1.2.1 查看执行计划1.2.2 show profile分析1.2.3 trace 2 索引失效2.1 准备工作2.1.1 创建user表2.1.2 插入数据2.1.3 查看数据库版本 2.2 联合索引2.2.1 联合索引中索引有效2.2.2 联合索引中索引失效2.2.3 MySQL 8中索…

Mysql索引失效

一.前言 针对Mysql数据库索引失效问题网上&#xff0c;有很多见解和答案。最近面试也是时常会被问道的一个知识点&#xff0c;简单的整理一下,省的以后忘记。 二.导致索引失效的几个情况 1.模糊查询:like %&#xff1b;like %%通配符放在开头会导致索引失效。会进行全表扫描…

详解MySQL索引失效的几种情况

MySQL索引是提高查询效率的重要手段。索引失效会导致查询效率下降&#xff0c;甚至全表扫描&#xff0c;影响数据库性能。以下是可能导致MySQL索引失效的情况&#xff1a; 1. 使用or操作符 当where语句中使用or操作符并且or两边的条件涉及到至少两个字段时&#xff0c;MySQL无…

mysql索引失效的常见9种原因详解

目录 前言&#xff1a; 1.最佳左前缀法则 2.主键插入顺序 3.计算、函数、类型转换(自动或手动)导致索引失效 4.范围条件右边的列索引失效 5.不等于(! 或者<>)导致索引失效 6.is null可以使用索引&#xff0c;is not null无法使用索引 7.like以通配符%开头索引失效…

【第三篇】MySQL 索引失效的常见原因【重点】

1.1 概述 有时候不知道小伙伴有没有跟我一样的情况&#xff0c;明明已经建立了索引&#xff0c;但是通过explain发现语句并没有使用上索引&#xff0c;这可能是某些原因导致了我们的索引失效。所以本篇主要介绍的是索引失效的常见原因和如何用好索引&#xff0c;给有需要的朋友…

你的凭据不工作,之前用于连接到(服务器IP)的凭据无法工作,请输入新的凭据(中英文均有)

之前windows还能够访问远程桌面&#xff0c;更新了系统发现又不行了&#xff0c;所以记录一下&#xff0c;解决方案&#xff1a; 在搜索里面输入gpedit.msc&#xff0c;进入到本地组策略编辑器&#xff1a; 中文版&#xff0c;把蓝色选中的策略改为&#xff08;经典&#xff…

远程桌面提示:你的凭据不工作

<<记录>> 远程连接服务器的时候&#xff0c;一直提示“你的凭据不工作”&#xff0c;连接失败。在网上找了很多办法&#xff0c;在注册表里设置凭据&#xff0c;或是添加windows新建凭证管理器等都不行。 如下图所示&#xff1a; 解决办法&#xff1a; 在输入用户…

Win10远程连接凭据不工作问题

Win10远程连接凭据不工作问题 今天为了远程连接可谓是煞费苦心&#xff0c;不过功夫不负有心人&#xff0c;问题终于解决了&#xff0c;不过在解决问题的过程中确实踩了无数的坑&#xff01;&#xff01;&#xff01;&#xff01; 话不多说&#xff0c;直接上干货。 当远程连接…

远程桌面失败:你的凭据不工作

方法一&#xff1a; 运行WinR&#xff0c;输入secpol.msc或是gpedit.msc: 然后按照以下操作&#xff0c;将默认设置“仅来宾—本地用户以来宾身份验证”&#xff0c;更改为“经典&#xff1a;本地用户以自己的身份验证”。 方法二&#xff1a; 更改远程桌面服务端的一个远程服…

win10远程桌面连接凭据怎么设置_win10系统连接远程桌面提示你的凭据不工作的解决方法...

无论谁在使用电脑的时候都可能会发现连接远程桌面提示你的凭据不工作的问题&#xff0c;连接远程桌面提示你的凭据不工作让用户们很苦恼&#xff0c;这是怎么回事呢&#xff0c;连接远程桌面提示你的凭据不工作有什么简便的处理方式呢&#xff0c;其实只要依照在Windows10系统桌…

win10 win11 远程连接 凭据不工作 无法建立连接

Windows 远程连接 远程连接个人或者学校电脑&#xff08;Windows系统&#xff09;时经常遇到无法连接的情况。本文结合两种情况给出相应解决方法。 No.1 问题描述 无法建立连接、未知连接错误 解决方法 查看目标ipv4地址是否正确&#xff0c;在windows&#xff08;WinR&#…