什么情况下需要创建MySQL索引?
2014-10-22 09:13
501 查看
索引可以提高数据的检索效率,也可以降低数据库的IO成本,并且索引还可以降低数据库的排序成本。排序分组操作主要消耗的就是CPU资源和内存,所以能够在排序分组操作中好好的利用索引将会极大地降低CPU资源的消耗。
如何判定是否需要创建索引?
1、较频繁地作为查询条件的字段
这个都知道。什么是教频繁呢?分析你执行的所有SQL语句。最好将他们一个个都列出来。然后分析,发现其中有些字段在大部分的SQL语句查询时候都会用到,那么就果断为他建立索引。
2、唯一性太差的字段不适合建立索引
什么是唯一性太差的字段。如状态字段、类型字段。那些只存储固定几个值的字段,例如用户登录状态、消息的status等。这个涉及到了索引扫描的特性。例如:通过索引查找键值为A和B的某些数据,通过A找到某条相符合的数据,这条数据在X页上面,然后继续扫描,又发现符合A的数据出现在了Y页上面,那么存储引擎就会丢弃X页面的数据,然后存储Y页面上的数据,一直到查找完所有对应A的数据,然后查找B字段,发现X页面上面又有对应B字段的数据,那么他就会再次扫描X页面,等于X页面就会被扫描2次甚至多次。以此类推,所以同一个数据页可能会被多次重复的读取,丢弃,在读取,这无疑给存储引擎极大地增加了IO的负担。
3、更新太频繁地字段不适合创建索引
当你为这个字段创建索引时候,当你再次更新这个字段数据时,数据库会自动更新他的索引,所以当这个字段更新太频繁地时候那么就是不断的更新索引,性能的影响可想而知。大概被检索几十次会更新一次的字段才比较符合建立索引的规范。而如果一个字段同一个时间段内被更新多次,那么果断不能为他建立索引。
4、不会出现在where条件中的字段不该建立索引
这个相信大家都知道。
您可能感兴趣的文章:
相关文章推荐
- 什么情况下需要创建MySQL索引?
- 什么情况下需要建立mysql索引
- 关于Mysql索引的一点思考--什么情况下索引不会被用到
- MySQL索引,如何正确创建MySQL索引,如何判断是否需要创建索引
- MYSQL 索引类型、什么情况下用不上索引、什么情况下不推荐使用索引
- MYSQL 索引类型、什么情况下用不上索引、什么情况下不推荐使用索引
- 【索引失效】什么情况下会引起MySQL索引失效
- mysql什么情况下不会使用索引
- MySQL创建索引需要注意的地方
- MYSQL 索引类型、什么情况下用不上索引、什么情况下不推荐使用索引
- 数据库的索引,mysql中的索引|||如何在mysql中对text字段加索引?|||mysql数据库中的字段在什么情况下加索引?|||高手请进:text字段不能做索引,有无其他方法?|||该建那个字段
- 数据库创建索引有什么优点和缺点
- MySQL对表的修改(增加或删减列,创建或取消索引等)
- 什么情况导致全表扫描,而不是用索引
- 什么情况下应该建立索引,索引优化及分析
- MySQL索引的查看创建和删除
- 详解mysql索引总结----mysql索引类型以及创建
- 分享MySQL提高至少100%的效率的sum索引创建示例
- MySQL里创建索引(Create Index)的方法和语法结构及例子,
- MySQL 创建索引(Create Index)的方法和语法结构及例子