Mysql索引使用情况_介绍mysql索引失效的情况

mysql视频教程栏目索引失效的情况。

5154d464d4fafe448e6a996ae7df2ba7.png索引对于MySQL而言,是非常重要的篇章。索引知识点也巨多,要想掌握透彻,需要逐个知识点一一击破,今天来先来聊聊哪些情况下会导致索引失效。

图片总结版

19798e54d0c125fbe7e1a8e5db5b9fd6.png相关免费学习推荐:mysql视频教程

全值匹配(索引最佳)explain select * from user where name = 'zhangsan' and age = 20 and pos = 'cxy' and phone = '18730658760';

b40e5c6cf544f952a419bf6334fe0562.png和索引顺序无关,MySQL底层的优化器会进行优化,调整索引的顺序

explain select * from user where name = 'zhangsan' and age = 20 and pos = 'cxy' and phone = '18730658760';

d3da49f6cc3963116f5c96733beb8200.png

1、违反最左前缀法则如果索引有多列,要遵守最左前缀法则

即查询从索引的最左前列开始并且不跳过索引中的列

explain select * from user where age = 20 and phone = '18730658760' and pos = 'cxy';

1abff2cd756086d1f6b42a436fdf7087.png

2、在索引列上做任何操作如计算、函数、(自动or手动)类型转换等操作,会导致索引失效从而全表扫描

explain select * from user where left(name,5) = 'zhangsan' and age = 20 and phone = '18730658760';

06915d843a70a51d467fada82b7e0f12.png

3、索引范围条件右边的列索引范围条件右边的索引列会失效

explain select * from user where name = 'zhangsan' and age > 20 and pos = 'cxy';

3797568b25fe62c52ac04916f8d3cb17.png

4、尽量使用覆盖索引只访问索引查询(索引列和查询列一致),减少select*

explain select name,age,pos,phone from user where age = 20;

38e19588153bb2d6afdc72c215d7100b.png

5、使用不等于(!=、<>)mysql在使用不等于(!=、<>)的时候无法使用索引会导致全表扫描(除覆盖索引外)

explain select * from user where age != 20;

explain select * from user where age <> 20;

bcba649f127c74a510f322265390b3b4.png

6056a4a0c27765c8bf1b1f5947480f6c.png

6、like以通配符开头('%abc')索引失效

explain select * from user where name like '%zhangsan';

29768f35c04877b4f1ff8854ef5d20b6.png索引生效

explain select * from user where name like 'zhangsan%';

785d0d8ea810c9fedcba7eb8b3000b59.png

7、字符串不加单引号索引失效explain select * from user where name = 2000;

ae2cf4a944b818e1937a5ea337f89196.png

8、or连接少用or

explain select * from user where name = '2000' or age = 20 or pos ='cxy';

e0cdccf9687389f2ca721285c792485a.png

9、order by正常(索引参与了排序)

explain select * from user where name = 'zhangsan' and age = 20 order by age,pos;

备注:索引有两个作用:排序和查找导致额外的文件排序(会降低性能)

explain select name,age from user where name = 'zhangsan' order by pos;//违反最左前缀法则

explain select name,age from user where name = 'zhangsan' order by pos,age;//违反最左前缀法则

explain select * from user where name = 'zhangsan' and age = 20 order by created_time,age;//含非索引字段

fd010fd9ee7cec7748f4427b954b954f.png

fb52f4460661c56eabf042d5ac14e830.png

100de380011abce07b0a7a136f2ee7eb.png

10、group by正常(索引参与了排序)

explain select name,age from user where name = 'zhangsan' group by age;

备注:分组之前必排序(排序同order by)

7619117c1d99e2540aaa3d563dbeb4e0.png导致产生临时表(会降低性能)

explain select name,pos from user where name = 'zhangsan' group by pos;//违反最左前缀法则

explain select name,age from user where name = 'zhangsan' group by pos,age;//违反最左前缀法则

explain select name,age from user where name = 'zhangsan' group by age,created_time;//含非索引字段

b61dfc442d968234e81d5c2b8c0a3908.png

24ac7f9bba948e38b99a9661041f3767.png

673d67067ebe3f45381b24d10268e9fb.png

使用的示例数据mysql> show create table user \G

******************************************************

Table: user

Create Table: CREATE TABLE `user` (

`id` int(10) NOT NULL AUTO_INCREMENT,

`name` varchar(20) DEFAULT NULL,

`age` int(10) DEFAULT '0',

`pos` varchar(30) DEFAULT NULL,

`phone` varchar(11) DEFAULT NULL,

`created_time` datetime DEFAULT NULL,

PRIMARY KEY (`id`),

KEY `idx_name_age_pos_phone` (`name`,`age`,`pos`,`phone`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci

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

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

相关文章

java 类 null_深入理解java中的null“类型”

本文研究的主要是java中的null“类型”的相关实例&#xff0c;具体介绍如下。先给出一道简单的null相关的题目&#xff0c;引发我们对null的探讨,后面会根据官方语言手册对null“类型”进行解读。题目&#xff1a;下面程序能正确运行吗&#xff1f;解析&#xff1a;输出应该为 …

如何彻底禁用Chrome浏览器的缓存功能

禁止Chrome浏览器的缓存功能有几种方式&#xff1a; 使用Shift F5强制刷新缓存。实际使用中我们发现&#xff0c;这种方法对于部分网页的更改并不能做到释放缓存的作用&#xff0c;尤其是无法释放DNS缓存。 使用隐身模式Shift Control N. 这种方法只能在打开的页面上消除之…

java int integer内存_java中一个integer对象的内存占用是多少?可以通过java方法输出吗?...

今天翻记录看到了自己15年3月份提的问题&#xff0c;现在已经18年6月份了&#xff1b;去年线上项目出现内存瓶颈&#xff0c;原因是缓存的玩家角色数据过多&#xff0c;在长时间不停服的情况下&#xff0c;导致数据越来越膨胀&#xff0c;之前没有清除无用缓存的机制&#xff0…

windows查看器无法打开图片_关于windows微软商城无法打开 错误代码0x80004003问题...

我本来是商城可以进 但是一打开里面的东西就无法打开 按下面的刷新就闪退 如下图操作桌面winr 运行 services.msc然后找到windows update打开就行 但是开启了系统会自动更新若是修改时显示拒绝访问桌面winr 输入regedit打开注册表 注册表找到HKEY_LOCAL_MACHINESYSTEMCurrentCo…

win10 java 反编译_win10下对.java源文件进行编译和反编译的步骤

1、先写好代码&#xff0c;如下找了个示例代码&#xff0c;文件名是Mutex.java&#xff1a;package com.huangshiyi.concurrent.cha04;import java.util.concurrent.TimeUnit;public class Mutex {private final static Object MUTEX new Object();public void accessResource…

电容屏物体识别_相比传统的触摸屏,电容式触摸屏的优势

点击蓝字&#xff0c;轻松关注今日话题 如今&#xff0c;我们的身边有着许多电子产品&#xff0c;主要是因为它便于我们的生活&#xff0c;所以我们的身边出现了许多触摸屏。对于电子产品&#xff0c;我们使用之前要了解清楚它的使用性能&#xff0c;掌握多点信息&#xff0c;这…

java底层机制_Java同步机制的底层实现

在多线程编程中我们会遇到很多需要使用线程同步机制去解决的并发问题&#xff0c;而这些同步机制就是多线程编程中影响正确性和运行效率的重中之重。这不禁让我感到好奇&#xff0c;这些同步机制是如何实现的呢&#xff1f;好奇心是进步的源泉&#xff0c;就让我们一起来揭开同…

payara 创建 集群_高可用性(HA),会话复制,多VM Payara群集

payara 创建 集群抽象 在研究如何创建高可用性&#xff08;HA&#xff09;时&#xff0c;我发现了会话复制&#xff0c;多机处理的Payara / GlassFish群集&#xff0c;无法在单个参考中找到所需的一切。 我认为这将是一个普遍的需求并且很容易找到。 不幸的是&#xff0c;我的假…

积分和人民币比率_通过比率路由到旧版和现代应用程序–通过Spring Cloud的Netflix Zuul...

积分和人民币比率从应用程序的旧版本迁移到应用程序的现代化版本时&#xff0c;一个非常常见的要求是能够将用户缓慢迁移到新应用程序。 在本文中&#xff0c;我将介绍通过Spring Cloud使用对Netflix Zuul的支持编写的这种路由层。 在继续之前&#xff0c;我必须承认&#xff0…

Java集合类原理详解

文章目录1 集合框架1.1 集合框架概述1.1.1 容器简介1.1.1 容器的分类1.2 Collection1.2.1 常用方法1.2.2 迭代器1.3 List1.3.1 概述1.3.2 常用方法1.3.3 实现原理1.4 Map1.4.1 概述1.4.2 常用方法1.4.3 Comparable 接口1.4.4 实现原理1.4.5 覆写 hashCode()1.5 Set1.5.1 概述1.…

sql安装联机丛书提示发生网络错误_速达软件:安装问题解答

问题Q&A在安装MSDE数据库时&#xff0c;出现安装程序倒退的情况解决方案&#xff1a;这是以前装过SQL Server数据库或MSDE数据库,没有卸载干净.解决办法重装操作系统。安装MSDE数据库时&#xff0c;系统出现“读取文件C:\program files\Microsoft sql sever\mssql\data\msd…

java分布式系统开发_从微服务到分布式系统-Java开发人员生存指南

java分布式系统开发感觉像是对微服务的炒作正在慢慢地落到实处&#xff0c;并且我们的行业开始意识到&#xff0c;根据微服务背后的体系结构范式无法通过仅在现有组件之上公开一些HTTP接口来轻松创建一个系统。 。 我们似乎确实同意必须进行服务优化的基础架构&#xff0c;文化…

链表数据结构原理图/内存结构图/内存图

单项链表内存结构图&#xff08;也叫原理图&#xff09; 单项链表内存结构图

反射与泛型 java_Java的反射 和 泛型的一个问题

aluckdog模板方法在编译过程中类型擦除&#xff1a;update(T,UpdateOperations)退化成update(Object,UpdateOperations)&#xff1b;update(Query,UpdateOperations)退化成update(Query,UpdateOperations)&#xff1b;morphia的update方法不光是一个模板方法&#xff0c;还是一…

迭代器原理图

原理图&#xff1a; Iterator<String> it Collection.iterator();it 是集合Collection的视图&#xff0c;迭代器其实就是视图&#xff08;类似数据库的 view&#xff09;&#xff0c;可以理解为一张单列多行的表&#xff0c;如下图所示&#xff1a; 有人理解成单行多…

neo4j python 算法_图论与图学习(二):图算法

选自towardsdatascience作者&#xff1a;Mal Fabien机器之心编译参与&#xff1a;熊猫图(graph)近来正逐渐变成机器学习的一大核心领域&#xff0c;比如你可以通过预测潜在的连接来理解社交网络的结构、检测欺诈、理解汽车租赁服务的消费者行为或进行实时推荐。近日&#xff0c…

cobol和java_现代化历险:策略+将COBOL转换为Java的示例

cobol和java在Keyhole Software&#xff0c;我们在很大程度上是一家现代化公司。 我们有一些顾问&#xff0c;专门研究将旧的代码迁移到新的&#xff0c;翻新的残旧代码库&#xff0c;并为大多数已经被供应商锁定的企业设计更光明的未来。 作为这些经验的一个有趣的副作用&…

递归算法 流程图_什么是算法?如何学习算法?算法入门的学习路径

什么是算法&#xff1f;有一个很著名的公式 “程序数据结构算法”。曾经跟朋友吃饭的时候我问他什么是算法&#xff0c;他说算法嘛&#xff0c;就是一套方法&#xff0c;需要的时候拿过来&#xff0c;套用就可以&#xff0c;我吐槽他&#xff0c;他说的是小学数学题的算法&…

envoy重试_具有Envoy代理的微服务模式,第二部分:超时和重试

envoy重试该博客是系列文章的一部分&#xff0c;该系列文章更深入地介绍了Envoy Proxy和Istio.io &#xff0c;以及它如何实现一种更优雅的连接和管理微服务的方式。 跟随我christianposta &#xff0c;紧跟这些博客文章的发布。 什么是Envoy代理 &#xff0c;它如何工作&…

网络研讨室_即将举行的网络研讨会:调试生产中Java的5种最佳实践

网络研讨室您的团队是否花费超过10&#xff05;的时间在生产中调试Java&#xff1f; 将新代码部署到生产中是一项艰巨的任务。 在您的本地环境中起作用的东西在生产中的作用并不相同&#xff0c;您可以通过用户来了解。 不理想吧&#xff1f; 生产中的调试是一个关键要素&…