本文介绍: ALL是全表扫描,就是啥索引也不用。index是对索引表进行全扫描,这样做的好处是不再需要数据进行排序,但是开销依然很大。—以上是效果不咋样的,下面开始就是能发挥出索引优势的级别了—range用到范围了一般是where中有&gt; < in between了,能利用上索引。ref 类型表示采用了非唯一索引,或者是唯一索引的非唯一前缀返回数据返回可能是多条。因为虽然使用了索引,但该索引列的值并不唯一,有重复。这样即使使用索引快速查找到了第一条数据,仍然不能停止,要进行目标值附近的小范围扫描

前缀索引

这个操作是为了减少索引长度,即占用空间的。这样一个可以多存一些索引,查找时候就会更快了。但是前缀索引有俩缺点,一个是ORDER BY或GROUP BY时候没法用,另一个是没法用做覆盖索引(因为索引本来自己都不全,没法提供完整信息,还是需要回表的)

覆盖索引

不需要那么多信息时候,可以考虑这一点

主键索引最好是自增的

避免增加数据时候,主键插入在B+树的中间,导致树的复杂结构变化。自增的直接插在最后就行。另外主键别太长,因为它是作为value存到二级索引的B+树叶子节点的,太长了占用空间

索引最好设置为 NOT NULL

两个原因,一个是NULL会让优化器做选择适合增加复杂度,因为涉及到运算时候,NULL太复杂,比如进行索引统计时,count 会省略值为NULL 的行;另一个是NULL让行数据平白无故要增加记录,至少一个字节,如下图
在这里插入图片描述

防止索引失效

索引会失效的情况介绍在这篇文章了,具体用没用到索引,用了啥索引可以用EXPLAIN来看
在这里插入图片描述
对于执行计划参数有:

type 字段就是描述了找到所需数据时使用的扫描方式是什么,常见扫描类型执行效率从低到高的顺序为:

分别介绍一下:
ALL是全表扫描,就是啥索引也不用。index是对索引表进行全扫描,这样做的好处是不再需要对数据进行排序,但是开销依然很大。

—以上是效果不咋样的,下面开始就是能发挥出索引优势的级别了—

range是用到范围了一般是where中有&gt; < in between了,能利用上索引。

ref 类型表示采用了非唯一索引,或者是唯一索引的非唯一性前缀返回数据返回可能是多条。因为虽然使用了索引,但该索引列的值并不唯一,有重复。这样即使使用索引快速查找到了第一条数据,仍然不能停止,要进行目标值附近的小范围扫描。但它的好处是它并不需要扫全表,因为索引是有序的,即便有重复值,也是在一个非常小的范围内扫描。

eq_ref 类型是使用主键或唯一索引时产生的访问方式,通常使用在多表联查中。比如,对两张表进行联查,关联条件是两张表的 user_id 相等,且 user_id 是唯一索引,那么使用 EXPLAIN 进行执行计划查看的时候,type 就会显示 eq_ref

const 类型表示使用了主键或者唯一索引与常量值进行比较,比如 select name from product where id=1。

需要说明的是 const 类型和 eq_ref 都使用了主键或唯一索引,不过这两个类型有所区别const 是与常量进行比较查询效率会更快,而 eq_ref 通常用于多表联查中。

除了关注 type,我们也要关注 extra 显示的结果

这里说几个重要的参考指标

原文地址:https://blog.csdn.net/pige666/article/details/134660166

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。

如若转载,请注明出处:http://www.7code.cn/show_9179.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注