MySQL5.7性能优化系列(二)——SQL语句优化(2)——子查询-派生表-视图--概述

时间:2022-03-06 00:14:24

章节内容:

  • 使用Semi-join连接优化子查询、派生表、视图
  • 使用Materialization优化子查询
  • 优化派生表、视图
  • 使用Exist 策略优化子查询

概述

in或者any子查询

MySQL查询优化器具有不同的策略来评估子查询。对于IN(或= ANY)子查询,优化器具有以下选择:

  • Semi-join 半连接策略
  • Materialization物化策略
  • EXISTS 策略

not in (<>或者all) 子查询

对于NOT IN(或<> ALL)子查询,优化器具有以下选择:

  • Materialization物化策略
  • EXISTS 策略

派生表(from 子句中的子查询)

对于派生表(FROM子句中的子查询),优化器具有以下选项:

  • 将派生表合并到外部查询块中
  • 将派生表实现为内部临时表

视图

对于视图,优化器与派生表具有相同的选择。
- 将视图合并到外部查询块中
- 将视图实现为内部临时表

以下讨论提供了有关上述优化策略的更多信息。

注意:

使用子查询修改单个表的UPDATE和DELETE语句的限制,优化器不使用semi-join连接或Materialization子查询优化。作为解决方法,请尝试将其重写为使用连接而不是子查询的多表UPDATE和DELETE语句