>  기사  >  데이터 베이스  >  MySQLSQL优化:关联子查询的局限性

MySQLSQL优化:关联子查询的局限性

WBOY
WBOY원래의
2016-06-07 16:19:551126검색

这是MySQL SQL优化的第三篇。公司某个业务系统频繁抛出问题SQL,我们对此类SQL做了基本面统计: 此类SQL近期共执行了12次,最长一次花费480秒,最短286秒 t1表的rows有90多万,始终会扫描这么多不需要的数据 这是由于MySQL查询优化器在处理相关子查询方面存

   这是MySQL SQL优化的第三篇。公司某个业务系统频繁抛出问题SQL,我们对此类SQL做了基本面统计:

  此类SQL近期共执行了12次,最长一次花费480秒,最短286秒

  t1表的rows有90多万,始终会扫描这么多不需要的数据

  这是由于MySQL查询优化器在处理相关子查询方面存在局限性

  MySQL总是会将相关的外层表压到子查询中,它认为这可以更高效地查找数据行。

  如果是个小表,情况可能还不会引起我们注意,但是如果外层表示一个非常大的表,那么这个查询的性能会非常槽糕,

  很不幸,我们的场景刚好应了后者

  我们优化后的执行效果:

  Good Luck!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.