• mysql优化(上)

    普通类
    • 支持
    • 批判
    • 提问
    • 解释
    • 补充
    • 删除
    • 为什么需要优化

    客服业务受到SQL语句的影响非常大,在规模比较大的局点,往往因为一个小的SQL语
    句不够优化,导致数据库性能急剧下降,小型机idle所剩无几,应用服务器断连、超时,严
    重影响业务的正常运行。因此,称低效的SQL语句为客服业务的‘恶龙’并不过分。数据库
    的优化方法有很多种,在应用层来说,主要是基于索引的优化。本次秘笈根据实际的工作经
    验,在研发原来已有的方法的基础上,进行了一些扩充,总结了基于索引的SQL语句优化的
    降龙十八掌,希望有一天你能用其中一掌来驯服客服业务中横行的‘恶龙’。

    • 入门基础准备

    1、表的主键、外键必须有索引;
    2、数据量超过300的表应该有索引;
    3、经常与其他表进行连接的表,在连接字段上应该建立索引;
    4、经常出现在Where子句中的字段,特别是大表的字段,应该建立索引;
    5、索引应该建在选择性高的字段上;
    6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引;
    7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替:
    A、正确选择复合索引中的主列字段,一般是选择性较好的字段;
    B、复合索引的几个字段是否经常同时以AND方式出现在Where子句中?单字段查询
    是否极少甚至没有?如果是,则可以建立复合索引;否则考虑单字段索引;
    C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段
    索引;
    D、如果复合索引所包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的
    字段;
    E、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引;
    8、频繁进行数据操作的表,不要建立太多的索引;
    9、删除无用的索引,避免对执行计划造成负面影响;
    以上是一些普遍的建立索引时的判断依据。一言以蔽之,索引的建立必须慎重,对每个
    索引的必要性都应该经过仔细分析,要有建立的依据。因为太多的索引与不充分、不正确的
    索引对性能都毫无益处:在表上建立的每个索引都会增加存储开销,索引对于插入、删除、
    更新操作也会增加处理上的开销。另外,过多的复合索引,在有单字段索引的情况下,一
    般都是没有存在价值的;相反,还会降低数据增加删除时的性能,特别是对频繁更新的表来
    说,负面影响更大。

    • 标签:
    • 复合
    • 字段
    • 优化
    • mysql
    • 建立
    • 索引
  • 加入的知识群:
    学习元评论 (0条)

    评论为空
    聪明如你,不妨在这 发表你的看法与心得 ~



    登录之后可以发表学习元评论
      
暂无内容~~
顶部