1. 选择唯一性索引:
唯一性索引的值是唯一的,可以更快速的通过该索引来确定某条记录
2. 为经常需要排序:
分组和联合操作的字段建立索引:经常需要ORDER BY .GROUP BY.DISTINCT.UNION等操作的字段,排序操作会浪费很多的时间,如果为其建立索引可以有效的避免排序操作
3. 为经常使用查询条件的字段建立索引:
如果某个字段经常用来做查询条件,那么该字段的查询速度会影响整个表的查询速度
4. 限制索引的数目:
索引额数目不是越多越好 ,每个索引都会占用磁盘空间,索引越多需要的磁盘空间就越大,修改表的时候对索引的重构和更新就很慢,越多的索引会使表的更新变的很慢
5. 尽量使用字段长度较短的的索引
6. 尽量使用前缀来索引
7. 删除不再使用使用或者很少使用的索引
8. 最左前缀使用原则:
比如与建立a, b,c字段的复合索引的时候就相当于建立了(a,b)和(a,b,c)的索引其他的查询顺序是不会使用索引的,根据业务需求,where子句使用最频繁的一列放在最左边
9. =和in可以乱序:
比如a=1 b=2 c=3建立(a,b,c)的索引可以任意顺序,mysql的查询优化器可帮你优化成索引可以识别的形式
10. 尽可能的使用区分度高的列作为索引
11. 索引不能参与计算
12. 尽可能的扩展索引不要新建索引
mysql索引的使用规则
最新推荐文章于 2025-06-23 12:30:00 发布