- 8.2.2.1使用半联接转换优化IN和EXISTS子查询谓词
- 8.2.2.2通过实现来优化子查询
- 8.2.2.3使用EXISTS策略优化子查询
- 8.2.2.4通过合并或实现来优化派生表,视图引用和公用表表达式
- 8.2.2.5派生条件下推优化
MySQL查询优化器有多种策略可用于评估子查询:
- 对于具有使用子查询
IN
,= ANY
或EXISTS
谓词,优化器具有以下选择:- 半连接
- 物化
EXISTS
战略
- 对于一个使用子查询
NOT IN
,<> ALL
或NOT EXISTS
谓语,优化有以下选择:- 物化
EXISTS
战略
对于派生表,优化器具有以下选择(这也适用于视图引用和公用表表达式):
- 将派生表合并到外部查询块中
- 将派生表具体化为内部临时表
以下讨论提供了有关前面的优化策略的更多信息。
笔记
使用子查询修改单个表的UPDATE
和 DELETE
语句 的限制是,优化器不使用半联接或实现子查询优化。解决方法是,尝试将它们重写为使用联接而不是子查询的多表 UPDATE
和 DELETE
语句。
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
Oracle SQL 执行计划分析与优化指南
Digital Observer
446次阅读
2025-04-01 11:08:44
墨天轮个人数说知识点合集
JiekeXu
443次阅读
2025-04-01 15:56:03
MySQL数据库当前和历史事务分析
听见风的声音
426次阅读
2025-04-01 08:47:17
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
424次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
393次阅读
2025-04-25 15:30:58
MySQL 生产实践-Update 二级索引导致的性能问题排查
chengang
390次阅读
2025-03-28 16:28:31
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
357次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
355次阅读
2025-04-15 23:49:58
火焰图--分析复杂SQL执行计划的利器
听见风的声音
332次阅读
2025-04-17 09:30:30
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
331次阅读
2025-04-15 14:48:05
TA的专栏
热门文章
我的故障分析及处理思路分享(李真旭)
2020-10-22 11107浏览
公共子表达式消除(Common Subexpression elimination,CSE)
2020-08-26 6201浏览
Oracle数据库的跟踪和分析方法
2020-10-02 5058浏览
2.5.9使用systemd管理MySQL服务器
2020-10-20 4535浏览
初探华为云GaussDB (for MySQL)
2020-12-11 3868浏览
最新文章
28.4.4 INFORMATION_SCHEMA INNODB_BUFFER_POOL_STATS 表
2024-09-29 105浏览
28.4.3 INFORMATION_SCHEMA INNODB_BUFFER_PAGE_LRU 表
2024-09-29 65浏览
28.4.2 INFORMATION_SCHEMA INNODB_BUFFER_PAGE 表
2024-09-29 64浏览
28.4.1 INFORMATION_SCHEMA InnoDB 表参考
2024-09-29 69浏览
28.3.50 INFORMATION_SCHEMA VIEW_TABLE_USAGE 表
2024-09-29 69浏览