子查询(Subquery)的优化一直以来都是 SQL 查询优化中的难点之一。关联子查询的基本执行方式类似于 Nested-Loop,但是这种执行方式的效率常常低到难以忍受。
当数据量稍大时,必须在优化器中对其进行去关联化(Decoorelation 或 Unnesting),将其改写为类似于 Semi-Join 这样的更高效的算子。
前人已经总结出一套完整的方法论,理论上能对任意一个查询进行去关联化。本文结合 SQL Server 以及 HyPer 的几篇经典论文,由浅入深地讲解一下这套去关联化的理论体系。它们二者所用的方法大同小异,基本思想是想通的。
本文的例子都基于 TPC-H 的表结构。
子查询简介
子查询是定义在 SQL 标准中一种语法,它可以出现在 SQL 的几乎任何地方,包括 SELECT, FROM, WHERE 等子句中。
总
继续阅读与本文标签相同的文章
上一篇 :
如何有效避免“删库跑路”、“误操作”等事件的发生
下一篇 :
你的支付宝小程序接入花呗分期了吗?
-
重磅 | 物联网数据分析利器 阿里云发布时序数据库InfluxDB版
2026-05-22栏目: 教程
-
NoSQL | 选择阿里云数据库HBase版十大理由
2026-05-22栏目: 教程
-
虚拟机安装linux获取动态ip
2026-05-22栏目: 教程
-
5分钟带你了解Redis 5.0新功能 内含重量级特性解读
2026-05-22栏目: 教程
-
工程师笔记:我对数据库系统云原生化的一些思考
2026-05-22栏目: 教程
