mysql14 sql优化-索引失效
1.索引失效
先创建符合索引,三个字段
ALTER table abilityassessrecord add INDEX idx_customerno_roomno_abilityassessrecord_customername (customerno,roomno,customername); SHOW INDEX FROM abilityassessrecord;
2简单使用索引
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1
索引生效,key_len长度为4,只用到了索引的的customerno字段
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND roomno = 1
索引生效,key_len长度为12,用到了索引的的customerno和roomno字段
3)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND roomno = 1 AND customername = 'aaa'
索引生效,key_len长度为75,用到了索引的的customerno和roomno和customername字段
3复合索引的第一个字段必须使用到
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1
索引生效,key_len长度为4,只用到了索引的的customerno字段
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE roomno = 1
没有用到索引。复合索引要生效的话,复合索引的第一个字段需要被使用到
3)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername = 'aaa'
没有用到索引。复合索引要生效的话,复合索引的第一个字段需要被使用到
4索引字段需连续使用不断开
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND roomno = 1
索引生效,key_len长度为12,用到了索引的的customerno和roomno字段
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND customername = ''
索引生效,key_len长度为4,用到了索引的的customerno,但是customername没有用到。因为复合索引除了第一个字段需要被使用到,字段的使用需要连续(这里的连续是指按照插件索引时的三个字段的顺序,在条件里面哪个写在前面哪个写在后面不影响,只有用到了就行)。这里查询条件用到customerno和customername,但是索引中第二个字段roomno没有用到,断开了,索引只有customerno生效
3)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername = 'aaa' AND roomno = 1 AND customerno = 1
索引以生效,三个字段都用到了,在条件里面哪个写在前面哪个写在后面不影响,只有用到了就行
4)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE roomno = 1 AND customername = ''
没有用到索引,因为索引的第一个字段没有用到
5只查询索引字段
1)示例
EXPLAIN SELECT * FROM abilityassessrecord
没有用到索引,数据全文检索
2)示例
EXPLAIN SELECT customerno FROM abilityassessrecord
EXPLAIN SELECT roomno FROM abilityassessrecord
EXPLAIN SELECT customername FROM abilityassessrecord
EXPLAIN SELECT customerno,roomno FROM abilityassessrecord
EXPLAIN SELECT customerno,customername FROM abilityassessrecord
EXPLAIN SELECT roomno,customername FROM abilityassessrecord
EXPLAIN SELECT customerno,roomno,customername FROM abilityassessrecord
用到索引。这里由于查询的只是索引中包含的字段,所以可以直接在索引中查询返回,不用再去找数据表
3)示例
EXPLAIN SELECT customerno,roomno,customername,sex FROM abilityassessrecord
没有用到索引,效果和select*是一样的
4)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1
索引生效
6索引字段使用到计算、函数、类型转换会导致该字段及之后的字段失效
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno+1 = 1
索引失效,条件里面索引字段使用到计算、函数、类型转换(手动或者自动的),会导致索引失效
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE MOD(customerno,2) = 1
索引失效,条件里面索引字段使用到计算、函数、类型转换(手动或者自动的),会导致索引失效
3)示例
EXPLAIN SELECT *,MOD(customerno,2) mo FROM abilityassessrecord WHERE customerno = 1
索引生效,在select用到函数等不影响
4)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND roomno = 1
索引生效,key_len为12,用到了customerno和roomno
5)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername = 'aaa' AND MOD(roomno,2) = 1 AND customerno = 1
索引生效,key_len为4,因为roomno用到了函数,失效了,roomno它及它后面的customername 也跟着失效
7索引字段使用到!=、<>会导致该字段之后的字段失效
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername = 'aaa' AND roomno != 1 AND customerno = 1
索引生效,key_len124,用到了customerno和roomno,customername失效
8索引字段使用到is not null会导致该字段和之后的字段失效
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername = 'aaa' AND roomno is not null AND customerno = 1
索引生效,用到了customerno字段,roomno和customername失效
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername is null AND roomno = 1 AND customerno = 1
索引生效,三个字段都用到了,is null不影响索引的使用
9索引字段模糊查询like使用%开头会导致该字段和之后的字段失效
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername like '%aa%' AND roomno = 1 AND customerno = 1
索引生效,用到了customerno和roomno字段,roomno和customername失效
2)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customername like 'aa%' AND roomno = 1 AND customerno = 1
索引生效,三个字段都用到了
10使用or索引失效
1)示例
EXPLAIN SELECT * FROM abilityassessrecord WHERE customerno = 1 AND roomno = 1 or customername = 'aa'
索引失效
mysql14 sql优化-索引失效的更多相关文章
- 「MySQL高级篇」explain分析SQL,索引失效&&常见优化场景
大家好,我是melo,一名大三后台练习生 专栏回顾 索引的原理&&设计原则 欢迎关注本专栏:MySQL高级篇 本篇速览 在我们上一篇文章中,讲到了索引的原理&&设计原则 ...
- 160531、SQL优化-索引
SQL优化有很多方法,今天来说一说数据库索引. 举例说明: 假设有一个图书Book表,里面有字段id,name, isbn等.如果图书数量巨大的话,我们通过isbn查询通常是比较慢的. 添加数据库索引 ...
- SQL优化-索引
(一)深入浅出理解索引结构 实际上,您可以把索引理解为一种特殊的目录.微软的SQL SERVER提供了两种索引:聚集索引(clustered index,也称聚类索引.簇集索引)和非聚集索引(nonc ...
- mysql 开发进阶篇系列 3 SQL 优化(索引使用方法)
一. 本章介绍mysql中的索引的分类,存储,使用方法的介绍 1. 索引的存储分类 MyISAM存储引擎的表的数据和索引是自动分开存储的,各自是独立的一个文件, innodb 存储引擎的表的数据和索 ...
- Oracle sql 优化の索引监控
1.监视索引是否使用 除了主键是完整性约束而自动变为索引外,创建普通索引的目的就是为了提高查询速度,如果我们创建了索引而没有被使用,那么这些不被使用的索引将起到阻碍性能的作用. 语法: --检查某个索 ...
- sql优化,索引学习
- mybatis的sql语句导致索引失效,使得查询超时
mybaitis书写sql需要特别注意where条件中的语句,否则将会导致索引失效,使得查询总是超时.如下语句会出现导致索引失效的情况: with test1 as (select count(C_F ...
- 数据库sql优化总结之3--SQL优化总结
SQL是每个Java程序员必回的一项技能, 对于项目中的各种复杂业务, 你是否能写出高效率, 简洁的SQL对于项目的运行效率和稳定性是有非常大的作用的. 通过个人的理解和网上的资料总结了一下常见的S ...
- 数据库的规范和SQL优化技巧总结
现总结工作与学习中关于数据库的规范设计与优化技巧 1.规范背景与目的 MySQL数据库与 Oracle. SQL Server 等数据库相比,有其内核上的优势与劣势.我们在使用MySQL数据库的时候需 ...
- sql优化策略之索引失效情况二
详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp63 接第一篇索引失效分析:http://grefr.iteye.co ...
随机推荐
- AR Engine光照估计能力,让虚拟物体在现实世界更具真实感
AR是一项现实增强技术,即在视觉层面上实现虚拟物体和现实世界的深度融合,打造沉浸式AR交互体验.而想要增强虚拟物体与现实世界的融合效果,光照估计则是关键能力之一. 人们所看到的世界外观,都是由光和物质 ...
- C#结构体大小问题
using System; using System.Collections.Generic; using System.Linq; using System.Runtime.InteropServi ...
- Kubernetes_k8s持久化存储(亲测可用)
一.前言 新建具有两个节点的k8s集群,主节点(master节点/m节点)的ip地址是192.168.100.150,从节点(w1节点)的ip地址是192.168.100.151. 本文操作如何将po ...
- 2022csp普及组真题:乘方(pow)
2022csp普及组真题:乘方(pow) 题目 [题目描述] 小文同学刚刚接触了信息学竞赛,有一天她遇到了这样一个题:给定正整数 a 和 b ,求 a^b 的值是多少. a^b 即 b 个 a 相乘的 ...
- Axios 类似于for循环发送批量请求{:axios.all axios.spread}。
Axios的请求都是异步的!不能用for循环遍历去批量发送请求 那如果我们需要类似与这样的请求怎么办呢 for(let i =0;i<array.length;i++){ axios.post( ...
- vulnhub靶场之Chronos:1
准备: 攻击机:虚拟机kali.本机win10. 靶机:Chronos,下载地址:https://download.vulnhub.com/chronos/Chronos.ova,下载后直接vbox打 ...
- Python-WebSpider
(一)网路爬虫入门 1.0 爬虫是个啥 通过编写程序,模拟浏览器去上网,然后让其去互联网上抓取数据的过程 1.1 爬虫分类 通用爬虫 :抓取系统重要组成部分,抓取一整张页面的数据 聚焦爬虫:建立在通用 ...
- 【每日一题】【归并排序/堆排序&虚拟头结点】148. 排序链表-211220/220217【出栈时不断容易产生环状链表!】
给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 . 进阶: 你可以在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序吗? 方法1:归并排序+使用辅助函数 ...
- 【每日一题】【双指针、位运算】2022年2月3日-NC103 反转字符串
描述 写出一个程序,接受一个字符串,然后输出该字符串反转后的字符串.(字符串长度不超过1000) 答案:双指针 import java.util.*; public class Solution { ...
- 【离线数仓】Day01-用户行为数据采集:数仓概念、需求及架构、数据生成及采集、linux命令及其他组件常见知识
一.数据仓库概念 二.项目需求及架构设计 1.需求分析 2.项目框架 3.框架版本选型 服务器选型:云主机 服务器规划 三.数据生成模块 1.数据基本格式 公共字段:所有手机都包含 业务字段:埋点上报 ...