MySql中索引失效的情况及原因

embedded/2024/10/11 13:21:34/

 1.索引失效的情况


b15b654e4b2842679c522e23772c5988.png

这是正常查询情况,满足最左前缀,先查有先度高的索引。

1.

c742b1cb94fb4043b781f7556db377b7.png

注意这里最后一种情况,这里和上面只查询 name = '小米科技' 的命中情况一样。说明索引部分丢失!

2.

ef2d266c71f549669181280c2765077f.png

这里第二条sql中的,status > '1'  就是范围查询

3.

3b16db3340ca4170b614f3b2aa34b8f5.png

这里sql中对name索引进行了截取,导致索引失效。

4.

4074e42f369a4935aa2da42ef7514752.png

发送类型转换,导致索引失效。

5.

b56372c619a344b8be728c6a1c063772.png

dc946e2a9e1842d0bcfef1f34c406726.png


2.索引为什么失效

如图:多个键值的B+树,如果要排序的话,要先按照第一个元素的大小排序,在第一个元素相同的情况下,按照第二个元素进行排序,以此类推...

        1.为什么要遵从最左前缀法则就很好理解了:如果跳过前面的元素,比如说直接使用联合索引中第二个元素进行查询,那么对于该索引,整个二叉树是无序的

        2.为什么范围查询右边的索引会失效:

这个例子中:我们尝试使用索引查询:a > 1,b = 1的数据。可以看到索引b完全就是无序的,这个无序不但体现在叶子节点,非叶子节点也是如此,整棵树都是如此。

        3.模糊查询导致索引失效:我们知道 a like "%c%" 和 a like "%c" 都会导致索引失效。

这是因为索引如果按照字符串顺序排序,如:aab、aac、aad、baa、bab 都是先按照第一个字母排序,第一个字母相同的情况下按照第二个字母排序。如果使用"%c%" 和 "%c" 去匹配,都成无需的了,因为前面的字母没确定,和最左前缀法则类似。


http://www.ppmy.cn/embedded/119800.html

相关文章

linux热点、故障定位工具

文章目录 热点glances进程负载一览报表安装使用 pidstat多维度统计进程负载安装使用 iftop统计与外部IP的网络流量安装使用 故障存储IO异常网络IO异常 热点 glances进程负载一览报表 显示系统全局的CPU、RAM、SWAP、LOAD信息; 显示每个进程的block IO速度、cpu耗用…

D. Determine Winning Islands in Race (cf div2,dp、图论最短路)

D. Determine Winning Islands in Race 思路: bfs找到E到达每个点的最短时间t[i]。 如果E要超过B&#xff0c;那么一定要借助辅助桥&#xff0c;从而获胜。 假设有u->v的辅助桥&#xff0c;E能通过这个桥超过B的条件是: s>u 且 t[v] < v-s 即 s的取值要为[u1,v-t[v]-…

java基础(4)类和对象

目录 1.前言 2.正文 2.1类的定义与使用 2.1.1类的定义 2.1.2类的实例化 2.1.3this引用 2.1.3.1 访问当前对象的成员变量 2.1.3.2调用当前对象的成员方法 2.1.3.3构造函数中的 this 2.1.3.4归纳this 2.2封装 2.2.1封装的定义 2.2.2访问修饰符 2.3static 2.3.1sta…

Spring Boot 点餐系统:提升您的餐饮体验

第一章 绪 论 1.1背景及意义 系统管理也都将通过计算机进行整体智能化操作&#xff0c;对于网上点餐系统所牵扯的管理及数据保存都是非常多的&#xff0c;例如管理员&#xff1b;首页、个人中心、用户管理、美食店管理、美食分类管理、美食信息管理、美食订单管理、美食评价管理…

828华为云征文 | 智能监控新篇章,Prometheus如何在华为云Flexusx容器环境中大展身手

前言 在数字化转型的浪潮中&#xff0c;智能监控成为企业IT战略的关键环节。部署在华为云Flexus X实例上的Prometheus监控系统&#xff0c;凭借其卓越的性能与灵活性&#xff0c;正开启智能监控的新篇章。Flexus X实例以其强大的计算能力和灵活的资源管理&#xff0c;为Prometh…

Oracle 数据库安装和配置指南(新)

目录 1. 什么是Oracle数据库&#xff1f; 2. 安装前的准备工作 2.1 硬件要求 2.2 软件要求 2.3 下载Oracle安装包 3. Oracle数据库的安装步骤 3.1 Windows系统安装步骤 3.2 Linux系统安装步骤 4. 配置Oracle数据库 4.1 设置环境变量&#xff08;Linux&#xff09; 4.…

uni-app进度条

<template><view><canvas canvas-id"ring" id"ring" style"width: 200px; height: 180px;"><!-- <p>抱歉&#xff0c;您的浏览器不支持canvas</p> --></canvas></view> </template><…

unity 中向指定的动画片段添加动画事件,并播放动画,同时获取动画片段的时长。

示例一 using UnityEngine;using System;public static class AnimationUtils{/// <summary>/// 向指定的动画片段添加动画事件&#xff0c;并播放动画&#xff0c;同时获取动画片段的时长。/// </summary>/// <param name"_animator">需要添加动画…