加入收藏 | 设为首页 | 会员中心 | 我要投稿 网站开发网_马鞍山站长网 (https://www.0555zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长百科 > 正文

巧用这19条MySQL优化,效率至少提高3倍

发布时间:2019-01-29 05:05:38 所属栏目:站长百科 来源:喜欢拿铁的人
导读:副标题#e# 本文我们来谈谈项目中常用的MySQL优化方法,共19条,具体如下: 1、EXPLAIN 做MySQL优化,我们要善用EXPLAIN查看SQL执行计划。 下面来个简单的示例,标注(1、2、3、4、5)我们要重点关注的数据: type列,连接类型。一个好的SQL语句至少要达到rang

1)MySQL中没有full join,可以用以下方式来解决:

  1. select * from A left join B on B.name = A.namewhere B.name is nullunion allselect * from B; 

2)尽量使用inner join,避免left join:

参与联合查询的表至少为2张表,一般都存在大小之分。如果连接方式是inner join,在没有其他过滤条件的情况下MySQL会自动选择小表作为驱动表,但是left join在驱动表的选择上遵循的是左边驱动右边的原则,即left join左边的表名为驱动表。

3)合理利用索引:

被驱动表的索引字段作为on的限制字段。

4)利用小表去驱动大表:

巧用这19条MySQL优化,效率至少提高3倍

从原理图能够直观的看出如果能够减少驱动表的话,减少嵌套循环中的循环次数,以减少 IO总量及CPU运算的次数。

5)巧用STRAIGHT_JOIN:

inner join是由MySQL选择驱动表,但是有些特殊情况需要选择另个表作为驱动表,比如有group by、order by等「Using filesort」、「Using temporary」时。STRAIGHT_JOIN来强制连接顺序,在STRAIGHT_JOIN左边的表名就是驱动表,右边则是被驱动表。在使用STRAIGHT_JOIN有个前提条件是该查询是内连接,也就是inner join。其他链接不推荐使用STRAIGHT_JOIN,否则可能造成查询结果不准确。

巧用这19条MySQL优化,效率至少提高3倍

这个方式有时能减少3倍的时间。

以上19条MySQL优化方法希望对大家有所帮助!

【编辑推荐】

  1. 为什么Oracle不断抨击自家品MySQL?
  2. 如何在MySQL 8中重置root密码
  3. 数据库大师成长日记:SQL Server如何防止开发人员获取敏感数据
  4. 简单实现MySQL数据库的日志审计
  5. MySQL数据库设计总结
【责任编辑:未丽燕 TEL:(010)68476606】
点赞 0

(编辑:网站开发网_马鞍山站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!