章节内容:
- 使用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语句