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

article/2025/9/30 2:07:55

MySQL索引是提高查询效率的重要手段。索引失效会导致查询效率下降,甚至全表扫描,影响数据库性能。以下是可能导致MySQL索引失效的情况:

1. 使用or操作符

当where语句中使用or操作符并且or两边的条件涉及到至少两个字段时,MySQL无法使用索引,会转向全表扫描。因此,应尽量避免使用or操作符。

原因:因为MySQL中的索引是根据某个字段进行排序建立的。当使用or操作符,说明有两个条件其中某个条件成立即可,而我们使用某个索引时只能判断出对应字段的条件是否成立,即使不成立,另一个条件成立时该记录也符合我们要查询的结果。所以使用索引无法做出判断。

例:

-- id为主键索引
EXPLAIN SELECT * FROM test WHERE id > 1 OR `name` = 'zs';

 

可以看出type为ALL:全表扫描

EXPLAIN SELECT * FROM test WHERE id > 3 OR id < 1;

 

可以看出type为PRIMARY:使用了主键索引;

2. 复合索引失效

如果使用了复合索引,但查询时未使用索引的第一列,索引也会失效。

原因:比如我们根据字段(t1,t2,t3)建立了复合索引,则排序规则是先按t1字段进行排序,t1字段相同再按t2字段排序,当t1、t2字段都相同时再按t3字段进行排序。如果我们的查询条件中没有使用到第一列,那么该索引也就没有办法使用。

例:

-- t1、t2列建立了符合索引
EXPLAIN SELECT * FROM test WHERE t1 = '1' AND t2 = '2';

  

可以看出type为ref:使用了二级索引;(当使用二级索引列于常数进行等值比较时,访问方法为ref)

-- 未使用索引的第一列t1
EXPLAIN SELECT * FROM test WHERE t2 = '1';

  

可以看出type为ALL:全表扫描

3. like查询

如果使用了like且以%开头,则索引会失效。

原因:模糊查询一般用在字符串的字段上,而字符串的排序规则为按字母字典序排序,如果以%开头,表示前面的字符取啥都行,则无法使用索引。

例:

EXPLAIN SELECT * FROM test WHERE t1 LIKE '1%';

 

可以看出type为range:使用二级索引进行范围查询。

EXPLAIN SELECT * FROM test WHERE t1 LIKE '%1';

 

可以看出type为ALL:全表扫描

4. 索引列上使用函数

原因:因为索引保存的是索引字段的原始值,而不是经过函数计算后的值,自然就没办法走索引了。

explain select * from test where length(t1) = 2;

  

5. 隐式类型转换

隐式类型转换规则:

  • 如果一个或两个参数都是NULL,比较的结果是NULL,除了安全的<=>相等比较运算符。对于NULL <=> NULL,结果为true。不需要转换。

  • 如果比较操作中的两个参数都是字符串,则将它们作为字符串进行比较。

  • 如果两个参数都是整数,则将它们作为整数进行比较。

  • 十六进制值如果不与数字进行比较,则被视为二进制字符串。

  • 如果其中一个参数是十进制值,则比较取决于另一个参数。 如果另一个参数是十进制或整数值,则将参数与十进制值进行比较,如果另一个参数是浮点值,则将参数作为浮点值进行比较(但没有将整数类型转换为浮点类型)。

  • 如果其中一个参数是TIMESTAMP或DATETIME列,另一个参数是常量,则在执行比较之前将常量转换为时间戳。

  • 在所有其他情况下,参数都是作为浮点数(双精度)比较的。

隐式类型转换会导致索引失效,比如当字段类型为字符串且建有索引,而查询条件类型为数值时,会将字符串类型隐式转换为浮点型,此时索引会失效。

原因:字符串类型转换为浮点数会使用cast函数,此时索引列上使用函数,导致索引失效。

EXPLAIN SELECT * FROM test WHERE t1 = 1.1;

  

6. 对索引进行表达式计算

原因:因为索引保存的是索引字段的原始值,而不是 id + 1 表达式计算后的值,所以无法走索引,只能通过把索引字段的取值取出来,然后进行表达式的计算来进行条件判断,因此采用的就是全表扫描的方式。

-- num字段有二级索引
EXPLAIN SELECT * FROM test WHERE num = 1 + 10;

 

EXPLAIN SELECT * FROM test WHERE num + 1 = 10;

 


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

相关文章

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&#…

《远程连接》用户凭据不工作—解决办法!!

《远程连接》用户凭据不工作—解决办法&#xff01;&#xff01; 搜了很多教程发现并不管用&#xff0c;最后仔细观察才发现根本原因是什么&#xff01;&#xff01; 因为我两个电脑登的Microsoft不是同一个账户&#xff0c;所以用户名一直输入错误&#xff01;&#xff01;&…

远程计算机凭据不对,三种办法助你解决远程桌面提示“您的凭据不工作”的问题...

随着电脑的使用率越来越高&#xff0c;我们可能会遇到远程桌面提示“您的凭据不工作”的问题&#xff0c;要怎么处理呢&#xff1f;详细解决方法如下&#xff1a; 方法一&#xff1a;组策略编辑器设置身份验证 1、打开组策略编辑器。 找到开始--- 运行-- 输入 gpedit.msc&#…

【系统相关】远程连接,凭据不工作

前言&#xff1a; 在换电脑之前&#xff0c;我的电脑局域网远程配置成功很简单&#xff0c;但是换了电脑之后&#xff0c;按照常规配置就出现了问题&#xff0c;凭据不工作。先讲述常规配置&#xff0c;以win7为例。被远程电脑为B&#xff0c;远程操作电脑为A。 常规配置&#…

远程计算机登录时显示凭据不对,连接到远程计算机时凭据不工作

在域环境中&#xff0c;如果使用Vista及以上的操作系统&#xff0c;默认情况下&#xff0c;在连接到远程计算机时无法保存凭据。 当我们使用远程桌面连接时&#xff0c;即使已经勾选了“记住我的凭证”。 但是下次登录依然无法保存凭据&#xff0c;会提示“您的凭据不工作” 此…

Win10 远程桌面 你的凭据不工作

1.问题描述如图所示 2.问题可能原因 目标机器的访问权限设置为仅来宾身份&#xff0c;应该设置为经典模式。 3.解决问题 具体设置目标机器步骤&#xff1a; 开始-->运行->gpedit.msc->计算机配置->Windows设置->安全设置->本地策略->安全选项->网络…

WIN间远程桌面连接:你的凭据不工作解决(亲测有效)

WIN间远程桌面连接&#xff1a;你的凭据不工作解决(亲测有效) 注意&#xff1a;需要windows专业版设备 被连接端设置 设置 -》 系统 -》远程桌面 -》启用远程桌面&#xff0c;并记录电脑名称&#xff0c;控制中心 -》系统和安全 -》允许远程访问&#xff0c;设置如下&#xf…

远程连接提示凭据不工作

远程计算机的时候提示凭据不工作&#xff0c;查了一下&#xff0c;都说要配置gpedit.msc的网络访问&#xff0c;按照教程来了一遍没什么用&#xff0c;就想新建个账户连接试试看&#xff0c;然后...... 账户名称和全名竟然不是同一个&#xff01;&#xff01;&#xff01; 我…

您的凭据不工作

win10系统远程桌面弄了半天&#xff0c;就是一直显示“您的凭据不工作”&#xff0c;试了各种方法&#xff0c;包括之前写的一篇博客中的四种方法&#xff0c;但就是不行&#xff0c;后来无意见又一次尝试&#xff0c;找到了方法&#xff0c;如下图&#xff1a; 第一步设置&…

远程桌面技术之----“你的凭据不工作”

远程桌面技术之—-“你的凭据不工作” 远程桌面时&#xff0c;如果出现“你的凭据不工作”&#xff0c;请在被远程的主机上做一定的修改&#xff1a; 方法一&#xff1a; 进入“控制面板”->“凭据管理器”->“添加Windows凭据”->输入 要登录的服务器的IP地址、用…

WIN10远程连接WIN10报错:你的凭据不工作

很多用户在升级到win10系统之后&#xff0c;连接远程桌面功能的时候遇到这样一个错误&#xff0c;就是远程桌面提示“你的凭据不工作”&#xff0c;导致无法连接远程桌面&#xff0c;该怎么解决呢&#xff0c;下面为大家讲解一下Win10无法连接远程桌面提示“你的凭据不工作”的…

远程桌面连接提示你的凭据不工作怎么办?

当你在远程连接服务器时&#xff0c;是否有遇到远程连接服务器失败&#xff0c;凭据不工作的情况呢&#xff1f;相信多数朋友已经遇到过了&#xff0c;是什么原因导致了凭据不工作呢&#xff1f;今天飞飞来和你们说说凭据不工作的解决方法 1、打开运行&#xff08;快捷键WinR&…

您的凭据不工作 之前用于连接到%的凭据无法工作。请输入新凭据。

第一种解决方法&#xff1a;关闭共享的密码保护 网络共享中心-更改高级共享设置-所用网络-选择无密码保护的共享 第二种&#xff1a; winr 输入gpedit.msc 选择管理模板 -系统-凭据分配 选择允许分配保存的凭据用于仅ntlm服务器身份验证 选择已启用 点击显示输入TERMSRV/* 确…