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,一经查实,立即删除!

相关文章

java8根据某个id删选_Java 8可选

java8根据某个id删选在编程时&#xff0c;我们都面临着&#xff08;最&#xff09; 臭名昭著的NullPointerException 。 而且我相信我们所有人都同意&#xff0c;遇到NullPointerException也是一种痛苦。 为了使读者了解最新情况&#xff0c;著名的计算机科学家Tony Hoare引入了…

emacs python ide_Emacs Python IDE win7 x64

安装平台 win7 x64 &#xff0c;emacs 23.3.1snippet工具&#xff0c;可自定义一些模板&#xff1a;.emacs 配置如下(add-to-list load-path "~/.emacs.d/yasnippet")(require yasnippet) ;; not yasnippet-bundle(yas/global-mode 1)自动完成工具&#xff0c;其实只…

解决阿里云 ssh 远程连接短时间没操作就会断掉的问题

在本地主机&#xff08;例如&#xff1a;你自己的 MacBook&#xff09;中打开 sshd 的配置文件&#xff0c;命令语句如下&#xff1a; sudo vim /etc/ssh/sshd_config注意&#xff1a;使用用户 root 编辑配置文件&#xff0c;否则会报错。 找到下面这个两行&#xff08;/Clie…

oracle查看jdk文档_Oracle JDK 9 Early Access文档已更新

oracle查看jdk文档Raymond Gallardo于2017年4月4日发布的针对Oracle JDK 9的抢先 访问文档已更新&#xff0c;今天宣布对Oracle JDK9文档的抢先访问页面进行了更新。 Gallardo重点介绍了一些更新的部分&#xff0c;包括Oracle JDK 9的新增功能 &#xff0c; Oracle JDK 9迁移指…

python3 selenium_Python3+Selenium3自动化测试-(准备)

Python3Selenium3自动化测试-(准备)最近在学习selenium自动化测试相关的内容&#xff0c;所以将实际准备情况做一记录&#xff0c;# 系统&#xff1a;win10(64位)# 浏览器&#xff1a;Chrome(67.0)、Firefox(61.0)、IE# python版本&#xff1a;3.6.5# Selenium&#xff1a;3.13…

MacBook如何通过键盘快捷键输入特殊字符_特殊符号

符号快捷键说明–[ Option ][ - ]破折号[ Option ] [ / ]除号≠[ Option ][ ]不等号≤[ Option ][ < ]≥[ Option ][ > ][ Option ][ \ ]左指双角引号[ Option ][ ’ ]拉丁文小写字母AE…[ Option ][ ; ]水平省略号≈[ Option ][ X ]约等于Ω[ Option ][ Z ]希腊文大写…

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

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

wcg总决赛_关于总决赛

wcg总决赛可以将变量声明为final。 最终变量只能分配一次。 如果分配了最终变量&#xff0c;则将导致编译时错误&#xff0c;除非在分配前立即将其明确取消分配。 分配任何最终变量后&#xff0c;将永远无法对其进行更改。 如果变量引用任何对象的任何实例&#xff0c;它将继续…

python dump函数用法_Python中json库的load和dump函数

相信很多朋友都对python里面的json库非常熟悉&#xff0c;json这个东西简明易懂&#xff0c;还能储存数据&#xff0c;实在是非常方便。我一开始使用json是从爬虫接触的&#xff0c;那个时候只知道json.loads和json.dumps&#xff0c;当时ide确实会自动填充load函数和dump函数&…

如何彻底禁用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…

Linux命令行中的特殊符号_特殊字符

常用的特殊符号 符号说明#1.表示注释&#xff1b;2.命令提示符~表示用户主目录。切换到用户主目录下&#xff1a;cd ~&#xff0c;切换到用户主目录下的bin目录&#xff1a;cd ~/bin~表示当前目录。切换到当前目录下wwwroot目录&#xff1a;cd ~/wwwroot~-表示上次的工作目录。…

微信小程序css 华文琥珀_琥珀项目:较小的,面向生产力的Java语言功能

微信小程序css 华文琥珀Brian Goetz最近的消息欢迎来到琥珀&#xff01; 介绍Project Amber &#xff08; OpenJDK的一部分&#xff0c; 最初于1月提出 &#xff09;。 Goetz通过介绍“欢迎使用Amber项目&#xff0c;这是我们面向特定生产力的Java语言JEP的孵化场”的介绍打开了…

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…

Linux 删除指定目录下的文件/删除文件

文章目录删除当前目录下的所有类型的文件删除指定目录下的所有类型的文件用 find 命令在当前目录下查找普通文件并删除用 find 命令在指定目录下查找普通文件并删除用 find 命令的处理动作将当前目录及其子目录下的普通文件删除用 find 命令的处理动作将指定目录及其子目录下的…

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

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

gatling的环境配置_将Gatling集成到Gradle构建中–了解SourceSet和配置

gatling的环境配置我最近在一个项目中工作&#xff0c;我们不得不将出色的负载测试工具Gatling集成到基于Gradle的版本中。 有可用的gradle插件使此操作变得容易&#xff0c;其中有两个是this和this &#xff0c;但是对于大多数需求而言&#xff0c;只需简单执行命令行工具本身…

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

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

Linux下常用文本处理命令

Linux下面有很多经典的非常有用的命令&#xff0c;其中处理文本的命令就有很多。这些小工具经过了几十年时间的洗礼&#xff0c;现在已经变成了经典&#xff0c;已经变成了Linux下面的标准&#xff0c;其实它们一直是遵循着Linux的标准。下面就让我们一起看看这些经典的Linux文…