• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > 什么情况下需要创建MySQL索引?

什么情况下需要创建MySQL索引?

作者:yuxikuo_1 字体:[增加 减小] 来源:互联网 时间:2017-05-11

yuxikuo_1通过本文主要向大家介绍了mysql创建索引,mysql创建索引语句,mysql如何创建索引,mysql怎么创建索引,mysql 创建联合索引等相关知识,希望本文的分享对您有所帮助

索引可以提高数据的检索效率,也可以降低数据库的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条件中的字段不该建立索引

这个相信大家都知道。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 基于mysql全文索引的深入理解
  • mysql中索引使用不当速度比没加索引还慢的测试
  • MySQL 通过索引优化含ORDER BY的语句
  • MySQL一个索引最多有多少个列?真实的测试例子
  • MySQL的id关联和索引使用的实际优化案例
  • 分析MySQL中索引引引发的CPU负载飙升的问题
  • 什么情况下需要创建MySQL索引?
  • MYSQL中常用的强制性操作(例如强制索引)

相关文章

  • 2017-05-11基于SQL中的数据查询语句汇总
  • 2018-12-05MySQL中CHAR和VARCHAR类型演变和详解
  • 2018-12-05mysql存储过程中变量的定义赋值操作
  • 2017-05-11解析SQL 表结构信息查询 含主外键、自增长
  • 2018-12-05游标的作用及属性介绍
  • 2017-05-11linux下mysql提示"mysql deamon failed to start"错误的解决方法
  • 2018-12-05如何通过PHP实现Mysql数据库连接、查询、记录集等操作
  • 2017-05-11解析SQL语句中Replace INTO与INSERT INTO的不同之处
  • 2018-12-05SQL的模糊查询实例讲解
  • 2018-12-05了解sql语句中where和having的区别

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • 游标遍历的内容推荐
    • 数据库实现批量删除数据的操作方法(代码实例)
    • 用SQL语句解决mysql导入大数据文件的问题
    • oracle chm帮助文件下载
    • MySQL索引不生效的解决办法
    • sqlserver帐号被禁用如何处理
    • 安装mysql noinstall zip版
    • MYSQL 数据库命名与设计规范
    • 快速将珊瑚虫IP数据库转MS SQL2005的图文教程第1/2页
    • oracle数据库添加或删除一列的sql语句

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有