单页营销网站怎么做,系统管理在哪里,Wordpress 核心思想,微信制作网站公司简介前缀索引
这个操作是为了减少索引长度#xff0c;即占用空间的。这样一个页可以多存一些索引#xff0c;查找时候就会更快了。但是前缀索引有俩缺点#xff0c;一个是ORDER BY或GROUP BY时候没法用#xff0c;另一个是没法用做覆盖索引#xff08;因为索引本来自己都不全…前缀索引
这个操作是为了减少索引长度即占用空间的。这样一个页可以多存一些索引查找时候就会更快了。但是前缀索引有俩缺点一个是ORDER BY或GROUP BY时候没法用另一个是没法用做覆盖索引因为索引本来自己都不全没法提供完整信息还是需要回表的
覆盖索引
不需要那么多信息时候可以考虑这一点
主键索引最好是自增的
避免增加数据时候主键插入在B树的中间导致树的复杂结构变化。自增的直接插在最后就行。另外主键别太长因为它是作为value存到二级索引的B树叶子节点的太长了占用空间。
索引最好设置为 NOT NULL
两个原因一个是NULL会让优化器做选择适合增加复杂度因为涉及到运算时候NULL太复杂比如进行索引统计时count 会省略值为NULL 的行另一个是NULL让行数据平白无故要增加记录至少一个字节如下图
防止索引失效
索引会失效的情况介绍在这篇文章了具体用没用到索引用了啥索引可以用EXPLAIN来看 对于执行计划参数有
possible_keys 字段表示可能用到的索引key 字段表示实际用的索引如果这一项为 NULL说明没有使用索引 key_len 表示索引的长度 rows 表示扫描的数据行数 type 表示数据扫描类型我们需要重点看这个。
type 字段就是描述了找到所需数据时使用的扫描方式是什么常见扫描类型的执行效率从低到高的顺序为
All全表扫描index全索引扫描range索引范围扫描ref非唯一索引扫描eq_ref唯一索引扫描const结果只有一条的主键或唯一索引扫描。
分别介绍一下 ALL是全表扫描就是啥索引也不用。index是对索引表进行全扫描这样做的好处是不再需要对数据进行排序但是开销依然很大。
—以上是效果不咋样的下面开始就是能发挥出索引优势的级别了—
range是用到范围了一般是where中有 in between了能利用上索引。
ref 类型表示采用了非唯一索引或者是唯一索引的非唯一性前缀返回数据返回可能是多条。因为虽然使用了索引但该索引列的值并不唯一有重复。这样即使使用索引快速查找到了第一条数据仍然不能停止要进行目标值附近的小范围扫描。但它的好处是它并不需要扫全表因为索引是有序的即便有重复值也是在一个非常小的范围内扫描。
eq_ref 类型是使用主键或唯一索引时产生的访问方式通常使用在多表联查中。比如对两张表进行联查关联条件是两张表的 user_id 相等且 user_id 是唯一索引那么使用 EXPLAIN 进行执行计划查看的时候type 就会显示 eq_ref。
const 类型表示使用了主键或者唯一索引与常量值进行比较比如 select name from product where id1。
需要说明的是 const 类型和 eq_ref 都使用了主键或唯一索引不过这两个类型有所区别const 是与常量进行比较查询效率会更快而 eq_ref 通常用于多表联查中。
除了关注 type我们也要关注 extra 显示的结果。
这里说几个重要的参考指标
Using filesort 当查询语句中包含 group by 操作而且无法利用索引完成排序操作的时候,这时不得不选择相应的排序算法进行甚至可能会通过文件排序效率是很低的所以要避免这种问题的出现。Using temporary使了用临时表保存中间结果MySQL 在对查询结果排序时使用临时表常见于排序 order by 和分组查询group by。效率低要避免这种问题的出现。Using index所需数据只需在索引即可全部获得不须要再到表中取数据也就是使用了覆盖索引避免了回表操作效率不错