当前位置: 首页 > news >正文

【MySQL精通之路】SQL优化(1)-查询优化(9)-外部联接优化

主博客:

【MySQL精通之路】SQL优化(1)-查询优化-CSDN博客

上一篇:

【MySQL精通之路】SQL优化(1)-查询优化(8)-嵌套联接优化-CSDN博客

下一篇:

【MySQL精通之路】SQL优化(1)-查询优化(10)-外部联接简化-CSDN博客


外部联接包括LEFT JOINRIGHT JOIN

MySQL实现了一个A LEFT JOIN B 连接规范如下所示:

表B被设置为依赖于表A以及A所依赖的所有表。

表A被设置为依赖于LEFT JOIN条件中使用的所有表(B除外)。

LEFT JOIN条件用于决定如何从表B中检索行。(换句话说,不依赖WHERE子句中的任何条件。)

执行所有标准联接优化,但表总是在它所依赖的所有表之后读取。如果存在循环依赖关系,则会发生错误。

执行所有标准WHERE优化

如果a中有一行与WHERE子句匹配,但B中没有一行与ON条件匹配,则会生成一个额外的B行,所有列都设置为NULL。

如果您使用LEFT JOIN查找某些表中不存在的行,并且您有以下测试:WHERE部分中的col_name为NULL,其中col_name是声明为not NULL的列,MySQL在找到一行符合LEFT JOIN条件后,将停止搜索更多行(针对特定的键组合)。

RIGHT JOIN实现类似于LEFT JOIN,表角色颠倒。

如“外部联接优化”所述,右联接转换为等效的左联接。

对于LEFT JOIN,如果生成的NULL行的WHERE条件始终为false,则LEFT JON将更改为内部联接。例如,如果t2.column1为NULL,则以下查询中的WHERE子句将为false:

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;

在MySQL 8.0.14及更高版本中,常量文字表达式产生的不重要的WHERE条件在准备过程中被删除,而不是在优化的后期阶段。

提前去除掉不必要查询条件允许优化器将外部联接转换为内部联接;这可以改进具有外部联接的查询的计划,这些联接包含WHERE子句中的琐碎条件,例如:

SELECT * FROM t1 LEFT JOIN t2 ON condition_1 WHERE condition_2 OR 0 = 1

优化器现在在准备过程中看到0=1总是错误的,这使得OR 0=1是多余的,并将其删除,留下以下内容:

SELECT * FROM t1 LEFT JOIN t2 ON condition_1 where condition_2

现在优化器可以将查询重写为内部联接,如下所示:

SELECT * FROM t1 JOIN t2 WHERE condition_1 AND condition_2

如上,联接已被简化现在,如果这样做会产生更好的查询计划,优化器可以在表t1之前使用表t2。

要提供有关表联接顺序的提示,请使用优化器提示;

参见“优化器提示”。

或者,使用STRIGHT_JOIN;参见“SELECT语句”。

但是,STRIGHT_JOIN可能会阻止使用索引,因为它会禁用半联接转换;

请参阅“使用半联接转换优化IN和EXISTS子查询语句”。

 
 


 主博客:

【MySQL精通之路】SQL优化(1)-查询优化-CSDN博客

上一篇:

【MySQL精通之路】SQL优化(1)-查询优化(8)-嵌套联接优化-CSDN博客

下一篇:

【MySQL精通之路】SQL优化(1)-查询优化(10)-外部联接简化-CSDN博客

http://www.lryc.cn/news/356955.html

相关文章:

  • Python应用开发——30天学习Streamlit Python包进行APP的构建(1)
  • 轻兔推荐 —— 一个好用的软件服务推荐平台
  • LeetCode hot100-57-G
  • 基于Vue uni-app的自定义列表表格信息展示组件
  • 计网(部分在session学习章)
  • TypeScript 枚举
  • (1) 初识QT5
  • 2024年认证杯二阶段数学建模赛题浅析
  • Redis教程(十八):Redis的Redisson的看门狗机制
  • docker-compose 映射端口失败! docker端口映射失败 ,docker映射只能使用老端口,映射无法使用
  • AIGC笔记--基于PEFT库使用LoRA
  • yolo 算法 易主
  • 用这8种方法在海外媒体推广发稿平台上获得突破-华媒舍
  • 怎么调试前端文件:一步步揭开前端调试的神秘面纱
  • 【深入学习Redis丨第一篇】Redis服务器部署详解
  • git教程(IDEA + 命令行)
  • 树莓派部署harbor_arm64
  • Typora图床配置优化(PicGo-Core(command line) 插件 + gitee)
  • 开放式耳机推荐品牌:五款品质超凡机型必须选购
  • 【大数据面试题】31 Flink 有哪些重启方法
  • 【IDEA】Redis可视化神器
  • 深入分析 Android Activity (十一)
  • go语言切片、数组去重函数SliceUnique 支持所有值是可比较类型的切片或者数组去重
  • 微信小程序实现计算当前位置到目的地的距离
  • 灵动微单片机洗衣机方案——【软硬件开发支持】
  • EureKa是什么?
  • 【数据结构】直接选择排序详解!
  • vue3中的toRaw API
  • 接口响应断言-json
  • 全面盘点多模态融合算法及应用场景