时间:2021-07-01 10:21:17 帮助过:18人阅读
优化器可能会将其重写为EXISTS相关的子查询:
1.SELECT * FROM t1
2.WHERE EXISTS (SELECT t2.b FROM t2 WHERE where_condition AND t1.a=t2.b);
使用临时表的子查询实现避免了这种重写,并且使得可以仅执行一次而不是每行外部查询一次执行子查询。
对于要在MySQL中使用的物化的子查询,必须启用optimizer_switch系统变量materialization标志。启用实现标志后,实现应用于出现在任何地方的子查询谓词(在选择列表中,WHERE,ON,GROUP BY,HAVING或ORDER BY),适用于任何这些用例的谓词:
(oe_1, oe_2, ..., oe_N) [NOT] IN (SELECT ie_1, i_2, ..., ie_N ...)
oe [NOT] IN (SELECT ie ...)
以下示例说明了对UNKNOWN和FALSE谓词评估的等价性的要求如何影响是否可以使用子查询实现。假设where_condition仅包含从t2而不是t1的列,以便子查询不相关。
此查询可能会实现:
1.SELECT * FROM t1
2.WHERE t1.a IN (SELECT t2.b FROM t2 WHERE where_condition);
以下限制适用于使用子查询物化:
使用EXPLAIN查询可以提供优化器是否使用子查询物化的指示。与不使用实现的查询执行相比,select_type可能会从“依赖子查询”更改为“子查询”。这表明,对于将在每个外部行执行一次的子查询,实现使子查询只能执行一次。此外,对于扩展EXPLAIN输出,由以下SHOW WARNINGS显示的文本包括物化和物化子查询。
MySQL5.7性能优化系列(二)——SQL语句优化(3)——使用物化策略优化子查询
标签:一个 sql语句优化 类型 als express optimizer sel lob 重写