SQL优化之优化SELECT语句(外部联接优化)

178 阅读2分钟

SQL优化之优化SELECT语句(外部联接优化)

外部联接包括LEFT JOINRIGHT JOIN

MySQL实现如下: *A* LEFT JOIN *B* *join_specification*

  • 表*B被设置为依赖于表A*以及所依赖的所有表 A
  • 表格*A设置为取决于条件B*中使用的所有表格(除外)LEFT JOIN
  • LEFT JOIN条件用于确定如何从table中检索行 B。(换句话说,WHERE不使用该子句中的任何条件。)
  • 执行所有标准的连接优化,不同之处在于始终在表所依赖的所有表之后读取该表。如果存在循环依赖关系,则会发生错误。
  • WHERE执行 所有标准优化。
  • 如果其中有一行*A与该WHERE子句匹配,但没有一行B与该ON条件匹配 ,B*则会生成一个额外的 行,且所有列都设置为NULL
  • 如果您LEFT JOIN用来查找某张表中不存在的行,并且进行了以下测试:*col_name* IS NULL在该WHERE部分中,*col_name*声明为的列在哪里 NOT NULL,MySQL在找到后停止搜索更多行(针对特定的键组合)符合LEFT JOIN条件的一行。

RIGHT JOIN实现类似于LEFT JOIN表角色相反的实现。如“简化外部连接”所述,将右连接转换为等效的左连接。

对于LEFT JOIN,如果 WHERE条件对于生成的NULL行始终为false ,则将LEFT JOIN其更改为内部联接。例如, WHERE如果条款是在下面的查询错误的t2.column1NULL

SELECT * FROM t1 LEFT JOIN t2 ON (column1) WHERE t2.column2=5;

因此,将查询转换为内部联接是安全的:

SELECT * FROM t1, t2 WHERE t2.column2=5 AND t1.column1=t2.column1;

现在,如果这样做会导致更好的查询计划,那么优化器可以t2先于表使用表t1。要提供有关表连接顺序的提示,请使用STRAIGHT_JOIN;请参见 “ SELECT语句”。但是,STRAIGHT_JOIN由于禁用了半联接转换, 可能会阻止使用索引。请参见 “使用半联接转换优化子查询,派生表和视图引用”

更多内容欢迎关注我的个人公众号“韩哥有话说”,100G人工智能学习资料,大量后端学习资料等你来拿。

qrcode_for_gh_3214f9e3470a_258.jpg