mysql的索引和执行计划
一、mysql的索引
索引是帮助mysql高效获取数据的数据结构。本质:索引是数据结构
1:索引分类
普通索引:一个索引只包含单个列,一个表可以有多个单列索引。
唯一索引:索引列的值必须唯一 ,但允许有空值。
复合索引:一个索引包含多个列。
聚集索引:并不是一种单独的索引类型,而是一种数据存储方式。innodb磁盘存储,.ibd数据和索引放在一个文件夹下。
非聚集索引:不是聚集索引的,就是非聚集索引。
2:语法
查看索引 show index from table;
创建索引
create [unique] index indexname on table(columnname(length));
alter table 表名 add [unique] index [indexname] on (columnname(length));
删除索引 drop index [indexName] on table;
3:适合建索引
某一列相对来说唯一
经常用来查询显示的列
经常用来关联的列 where 条件中用到的列,以及join on 用到的列
二、mysql的执行计划
使用explan关键字可以知道mysql是如何处理SQL语句的。
id:相同,都不相同,不全部相同。
相同:获取select的执行顺序。执行顺序由上到下。
都不相同:如果是子查询,id序号会递增,id值越大优先级越高,越先被执行。
不全部相同:id相同的认为一组,从上往下顺序执行。在所有组中,id值越大,优先级越高,越先被执行。
select_type:查询的类型
simple:简单的SQL语句,不包含union或者子查询。
primary:查询中包含任何的子查询,最外层查询被标记。
subquery:在select和where中,查询的任何子查询。
derived:在from列表中包含子查询会被标记为derived,mysql会递归执行这些子查询,把结果放到临时表。
union:若第二个select出现在union之后,则标记为UNION;若UNION包含在from子句的子查询中,外层select将被标记为derived。
union result:从union表获取结果的select。
table:查询来自那张表
type:访问的类型,重要的一个指标,结果从最好到最坏。
system》const》eq_ref>ref>range>index>all,最好达到ref或者range
system:表中只有一条记录(等于系统表),这是const类型的特例,平时不会出现,这个可以忽略不计。
const:表示通过索引一次就找到了。用于primary或unique索引。因为只匹配一行数据。
eq_ref:唯一索引扫描,对于每个索引建,表中只有一条记录匹配。常见于主键或唯一索引扫描。
ref:非唯一索引扫描,返回匹配某个单独值的所有行。
rang:只检索给定范围内的行,使用一个索引来选择行。key列显示使用那个索引,一般就是在你的where语句中出现between、<、>、in查询中。
index:当查询的结果全为索引列的时候。也是全表扫描的一种。只不过扫描的全部索引。
all:全表扫描。
注:当出现index和all的时候,就应该去优化SQL语句。
key:实际所用的索引。如果为null,则没有使用索引。
possible_key:可能用到的key。possible_key有数据,但是不一定会使用key。key有数据,但是不一定会使用possible_key。这两者比一定都同时出现。
key_len:表示索引使用的字节数,通过该列查询使用索引的长度。在不损失精确性的情况下,长度越短越好。
ref:显示索引的哪一列被使用了,如果可能得话,是一个常数。
rows:根据表的以及索引选用的情况,大致估算出需要读取的行数。扫描的行数越少越好。
extra:包含不适合在其他列中显示,但重要的额外信息。
mysql的索引和执行计划的更多相关文章
- python/MySQL(索引、执行计划、BDA、分页)
---恢复内容开始--- python/MySQL(索引.执行计划.BDA.分页) MySQL索引: 所谓索引的就是具有(约束和加速查找的一种方式) 创建索引的缺点是对数据进行(修改.更新.删除) ...
- MySQL for OPS 03:索引和执行计划
写在前面的话 啥是索引?以一本书为例,如果想要找到某一指定章节的某一小节,书薄还好,如果书厚,可能就会找的头皮发麻.于是便出现了目录,让用户更容易查找到自己所需要的东西.索引就类似一张表的目录.其存在 ...
- MySQL学习系列2--MySQL执行计划分析EXPLAIN
原文:MySQL学习系列2--MySQL执行计划分析EXPLAIN 1.Explain语法 EXPLAIN SELECT …… 变体: EXPLAIN EXTENDED SELECT …… 将执行 ...
- MYSQL与TiDB的执行计划
前言 这里采用了tpc-h一个数据库的数据量来进行查询计划的对比.并借助tpc-h中的22条查询语句进行执行计划分析. mysql采用的是标准安装,TiDB采用的是单机测试版,这里的性能结果不能说明其 ...
- MySQL统计信息以及执行计划预估方式初探
数据库中的统计信息在不同(精确)程度上描述了表中数据的分布情况,执行计划通过统计信息获取符合查询条件的数据大小(行数),来指导执行计划的生成.在以Oracle和SQLServer为代表的商业数据库,和 ...
- 第九课——MySQL优化之索引和执行计划
一.创建索引需要关注什么? 1.关注基数列唯一键的数量: 比如性别,该列只有男女之分,所以性别列基数是2: 2.关注选择性列唯一键与行数的比值,这个比值范围在0~1之前,值越小越好: 其实,选择性列唯 ...
- 【mysql】mysql 调优之 ——执行计划 explain
1.what is explain(explain 是个什么东东) explain(解释),在 Mysql 中 作为一个关键词,用来解释 Mysql 是如何执行语句,可以连接 select .dele ...
- MySQL — 优化之explain执行计划详解(转)
EXPLAIN简介 EXPLAIN 命令是查看查询优化器如何决定执行查询的主要方法,使用EXPLAIN,只需要在查询中的SELECT关键字之前增加EXPLAIN这个词即可,MYSQL会在查询上设置一个 ...
- MySQL(四)执行计划
转载自:Oo若离oO,原文链接 在MySQL中使用explain查询SQL的执行计划 目录 一.什么是执行计划 二.如何分析执行计划 一.什么是执行计划 要对执行计划有个比较好的理解,需要先对MySQ ...
随机推荐
- MUI框架-08-窗口管理-创建子页面
MUI框架-08-窗口管理-创建子页面 之前写过这一篇,不知道为什么被删了,我就大概写了,抱歉 创建子页面是为了,页面切换时,外面的页面不动,让 MUI 写出来的页面更接近原生 app 官方文档:ht ...
- Python爬虫教程-08-post介绍(百度翻译)(下)
Python爬虫教程-08-post介绍(下) 为了更多的设置请求信息,单纯的通过urlopen已经不太能满足需求,此时需要使用request.Request类 构造Request 实例 req = ...
- spring单元测试报错:Failed to load ApplicationContext 的解决方法
使用idea 配置单元测试之后,配置完spring的注解@junit 和@runer 之后 一直报错. 最后发现是默认使用jdk1.8引起的,使用jdk1.7即可.
- 【Oracle】DBMS_STATS.GATHER_TABLE_STATS详解
由于Oracle的优化器是CBO,所以对象的统计数据对执行计划的生成至关重要! 作用:DBMS_STATS.GATHER_TABLE_STATS统计表,列,索引的统计信息(默认参数下是对表进行直 ...
- asp.net 服务器控件的 ID,ClientID,UniqueID 的区别
1.简述 ID是设计的时候自己所指定的ID,是我们分配给服务器控件的编程标识符,我们常常使用this.controlid来寻找控件,那么这个controlid就是这里所说的ID. ClientID是由 ...
- 计算机支持的最大内存与CPU之间的关系
在使用计算机时,其最大支持的内存是由 操作系统 和 硬件 两方面决定的. 先说一下硬件方面的因素,在计算机中 CPU的地址总线数目 决定了CPU 的 寻址 范围,这种由地址总线对应的地址称作为物理地 ...
- 用windows公文包实现不同盘符两个文件文件夹文件同步
需求:磁盘D的文件夹A需同步到磁盘E 步骤: 1.在磁盘E中新建公文包B 2.将D盘的文件夹A复制到公文包B 3.修改文件夹A中的内容 4.选中公文包B,右键"全部更新"
- 彻底解密 Spark 的 HashShuffle
本课主题 Shuffle 是分布式系统的天敌 Spark HashShuffle介绍 Spark Consolidated HashShuffle介绍 Shuffle 是如何成为 Spark 性能杀手 ...
- 初始python(一)
一.python特性概要 1. python是解释性脚本语言. 2. python特性总结 2.1 字节码 2.2 动态语义 在赋值是确定数据类型 2.3 缩进(4个空格) 3. python定义编码 ...
- 缓存MEMCACHE php调用
在项目中,涉及大访问量时,合理的使用缓存能减轻数据库的压力,同时提升用户体验.即在非实时性的需求的前提下,一小段时间内(若干秒),用于显示的数据从缓存中获取的,而不用直接读取数据库,能有效的减少数据库 ...