将外连接转换为内连接

原文链接:http://dcx.sybase.com/1201/zh/dbusage/queryopt-sectb-5356466.html


优化程序为其访问计划生成左深 (left-deep) 处理树。这一规则的唯一例外是存在右深 (right-deep) 嵌套外连接表达式的情况。查询执行引擎的用于计算 LEFT OUTER JOIN 或 RIGHT OUTER JOIN 的算法要求,保留的表必须在任何连接策略中先于提供空值的表。因此,只要可能,优化程序就会寻找机会将 LEFT 或 RIGHT 外连接转换为内连接,这是因为内连接是可交换的,它使优化程序在执行连接枚举时具有更大的自由度。

如果以下条件之一为真,则 LEFT 或 RIGHT 外连接会转换为内连接:

  • 不允许使用空值的谓语出现在查询的 WHERE 子句中,该谓语引用提供空值的表的列。由于该谓语不允许空值,因此将从结果中排除外连接生成的所有值为 NULL 的行,从而使该查询在语义上等效于内连接。
  • 外连接的提供空值的一侧为保留一侧的每行只返回一行。如果该条件为真,则不存在提供空值的行,并且外连接等效于内连接。

当查询引用使用外连接编写的一个或多个视图时,此重写优化可应用于外连接查询。该查询的 WHERE 子句可以包括限制输出的条件,以便从一个或多个表的表达式中排除所有提供空值的行,从而使这种优化适用。

 示例 1
 示例 2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值