性能优化-如何选择合适的列建立索引

3、如何选择合适的列建立索引

1、在where从句,group by从句,order by从句,on从句中的列添加索引
2、索引字段越小越好(因为数据库数据存储单位是以“页”为单位的,数据存储的越多,IO也会越大)
3、离散度大的列放到联合索引的前面

例子:

select * from payment where staff_id =2 and customer_id =584;

注意:是index(staff_id,customer_id)好,还是index(customer_id,staff_id)好 那我们怎么进行验证离散度好了?

A、我们先查看一下表结构

desc payment;

在这里插入图片描述

B、分别查看这两个字段中不同的id的数量,数量越多,则表明离散程度越大:因此可以通过下图看出:customer_id 离散程度大。
在这里插入图片描述

结论:由于customer_id 离散程度大,使用index(customer_id,staff_id)好

C、mysql联合索引

① 命名规则 :表名_字段名

1、需要加索引的字段,要在where条件中
2、数据量少的字段不需要加索引
3、如果where条件中是OR关系,加索引不起作用
4、符合最左原则

② 什么是联合索引

1、两个或更多个列上的索引被称作联合索引,又被称为是复合索引。
2、利用索引中的附加列,您可以缩小搜索的范围,但使用一个具有两列的索引 不同于使用两个单独的索引。复合索引的结构与电话簿类似,人名由姓和名构成,电话簿首先按姓氏对进行排序,然后按名字对有相同姓氏的人进行排序。如果您知 道姓,电话簿将非常有用;如果您知道姓和名,电话簿则更为有用,但如果您只知道名不姓,电话簿将没有用处。

所以说创建复合索引时,应该仔细考虑列的顺序。对索引中的所有列执行搜索或仅对前几列执行搜索时,复合索引非常有用;仅对后面的任意列执行搜索时,复合索引则没有用处。

发布了1080 篇原创文章 · 获赞 908 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/weixin_42528266/article/details/103998970