MySQL优化思路

主要考虑数据库优化与SQL语句优化

1,数据库优化,包括存储引擎的优化,缓存的优化和内存的优化等

2,SQL优化。首先先判断什么样的SQL需要优化。可以在MySQL中开启慢查询,设置成例如SQL执行时长超过5秒就可以定为慢SQL,并记录到日志中。然后拿到慢SQL的执行记录和计划,通过explain关键字做分析。分析思路有例如SQL存在索引,判断是否执行了索引或者索引失效原因,若索引未失效则要考虑索引创建是否合理,以及是否遵循最左匹配原则等

sql优化是一个比较复杂的话题。可以提供一个思路:

1。怎么识别慢sql——开启慢查询日志,设置慢查询阈值,使用通知平台(短信,企业微信,钉钉)等进行通知。

2.看下出问题的sql数据量多少,关联关系是怎么样的。有个大概的了解。

3.查看explain输出结果,关注type,key,key-len,rows,extro等(具体见官网)

4.索引优化:哪些列加到索引中,索引顺序的安排,索引失效的场景,索引覆盖和前缀索引,(索引列不是越多越好)

5.sql本身的优化,比如:仅仅select自身需要的列而不是select*,还有一些特殊场景的优化。

6.表结构的优化,冗余,汇总表,垂直拆分,水平拆分,分库分表等

7.其他手段,比如redis缓存,es等

额外

1、如果使用HDD的话,可以看下是否开启了mrr,mrr可以把随机读转化为顺序读,用了空间换时间思想提高了索引查询的性能。这个点估计百度MySQL优化都少提

2、分库分表

mysql优化前到后步骤

sql优化、索引优化、表结构优化、事务的处理、锁表的处理、系统配置的优化

相关链接

https://www.bilibili.com/video/BV1Yg411Y7Wh/?spm_id_from=333.337.search-card.all.click&vd_source=ef0b071800739bc6d2f80722ef46b698

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值