mysql数据库优化之 如何选择合适的列建立索引-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

mysql数据库优化之 如何选择合适的列建立索引

简介: mysql数据库优化之 如何选择合适的列建立索引 在where 从句,group by 从句,order by 从句,on 从句中出现的列; 索引字段越小越好; 离散度大的列放到联合索引的前面;比如:     select * from payment where staff_id = 2 and customer_id = 236;     针对上面的查询是  index(sftaff_id, customer_id) 好?还是index(customer_id, staff_id)好?     因为customer_id的离散度更大,因此用后面的更合适!! 那么问题来了。

mysql数据库优化之 如何选择合适的列建立索引

  1. 在where 从句,group by 从句,order by 从句,on 从句中出现的列;
  2. 索引字段越小越好;
  3. 离散度大的列放到联合索引的前面;比如:

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

    针对上面的查询是  index(sftaff_id, customer_id) 好?还是index(customer_id, staff_id)好?

    因为customer_id的离散度更大,因此用后面的更合适!!

那么问题来了。怎么判断离散度呢,可以使用 select count(distinct customer_id), count(distinct staff_id) from 表名

谁的值大,说明这一些列的离散度更高!
原文地址https://www.cnblogs.com/slsectyoufromwrold/p/10773783.html

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章
最新文章
相关文章