索引可以提高数据的检索效率,也可以降低数据库的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索引什么情况下创建02-28
- 解析mysql中insert的操作02-28
- 简单介绍Mysql的SQL服务器模式02-28
- MySQL和Django在Ubuntu14.04下的环境部署全过程02-28
- Ubuntu下MySQL中文乱码的问题解决办法介绍02-28
- 简单总结 MySQL数学函数02-28
- 详解centOS7下mysql插入中文字符报错问题的解决方法(图)02-28
- 详解centos7下mysql5.6的主从复制的示例代码分享02-28
相关推荐
-
雷神推出 MIX PRO II 迷你主机:基于 Ultra 200H,玻璃上盖 + ARGB 灯效
2 月 9 日消息,雷神 (THUNDEROBOT) 现已宣布推出基于英
-
制造商 Musnap 推出彩色墨水屏电纸书 Ocean C:支持手写笔、第三方安卓应用
2 月 10 日消息,制造商 Musnap 现已在海外推出一款 Oce
热文推荐
- MySQL索引什么情况下创建
MySQL索引什么情况下创建
26-02-28 - 简单介绍Mysql的SQL服务器模式
简单介绍Mysql的SQL服务器模式
26-02-28 - MySQL和Django在Ubuntu14.04下的环境部署全过程
MySQL和Django在Ubuntu14.04下的环境部署全过程
26-02-28 - Ubuntu下MySQL中文乱码的问题解决办法介绍
Ubuntu下MySQL中文乱码的问题解决办法介绍
26-02-28 - 详解centOS7下mysql插入中文字符报错问题的解决方法(图)
详解centOS7下mysql插入中文字符报错问题的解决方法(图)
26-02-28 - 详解navicat连接mysql时出现1045错误的解决方案
详解navicat连接mysql时出现1045错误的解决方案
26-02-28 - MySQL用户权限管理图文详解
MySQL用户权限管理图文详解
26-02-28 - 详解MySQL中把varchar类型转为date类型的方法
详解MySQL中把varchar类型转为date类型的方法
26-02-28 - mysql5.7.17在Windows10下安装配置方法的图文教程
mysql5.7.17在Windows10下安装配置方法的图文教程
26-02-28 - mysql数据迁移到Oracle的图文代码分析
mysql数据迁移到Oracle的图文代码分析
26-02-28
