星形转换 oracle,星型转换(Star Transformation)

所谓星型查询(Star Query),是指一个事实表(Fact Table)与多个维度表(Dimension Table) 的关联查询,并且维度表仅与事实表之间关联,维度表之间不存在关联关系。星型查询分为两个阶段:

•第一阶段是由事实表利用位图索引的位图信息(或者由 B*树索引的 ROWID 转换得来的位图信息)进行位图操作,进而获得相应数据集;

•第二阶段则将第一阶段获得的数据集与维度表进行关联,获取最终查询结果。星型转换即将事实表与多个维度表的普通关联查询转换为星型查询的一项优化技术。

提示:星型转换可以由参数 star_transformation_enabled 或者提示STAR_TRANSFORMATION/NO_STAR_TRANSFORMATION 控制

1be371f268b6bfeb7219f994f5f59b24.png

29069d19b7bb4e4bed526cc0bc4f16cd.png

3a4ecb24d2e66108175756a16f541402.png

adca1e2f9a1dd0c7e3fa1fe5bed6e580.png

排序消除(Order By Elimination,OBYE)

排序消除,是指优化器在生成执行计划之前,将语句中没有必要排序操作消除掉,从而避免在 执行计划中出现排序操作或由排序导致的操作(如 Index Full Scan)。

提示:排序消除可以由优化器参数_optimizer_order_by_elimination_enabled 或者提示ELIMINATE_OBY/NO_ELIMINATE_OBY 控制。

8bda46959162446803b19469835eecc3.png

Distinct 消除(Distinct Elimination)

根据表中主键、唯一约束信息,消除查询语句中的 DISTINCT。这是一项启发式的查询转换。

764c804f8f5dbb3436a3e5878d0c9b04.png

852e05ef65541c0b4c2e04e274a8925b.png

上例中,尽管在 SELECT 子句中存在 DISTINCT 关键字,但由于表上存在唯一性约束T_USERS_UK(USERNAME),但并它没有增加 SORT/HASH UNIQUE 操作来消除重复值。

表消除(Table Elimination)

表消除是查询转换器依据表之间的主外键关系、位图关联索引等信息,将复杂查询语句中不必要的读取的表消除掉的一项优化技术。由于表消除出现在连接查询语句里面,因此也称为连接消除(Join Elimination,JE)。

提示:表消除可以由优化器参数"_optimizer_join_elimination_enabled"和提示ELIMINATE_JOIN/NO_ELIMINATE_JOIN 控制。

主外键关系消除关联操作

查询转换器能够依据两表之间的主外键关系消除关联操作,消除对关联表的扫描。

1049d0195331c492f82c006d1908dad9.png

56b11ded82b45198fa4f8e4e7cae2368.png

在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_TABLESPACES 的扫描。

位图关联索引消除关联操作

查询转换器能够依据建立在主表上指向引用表的位图关联索引(Bitmap Join Index)来消除关联操作,消除对关联表的扫描。

(以下示例在 11.2.0.1 中运行):

db408c62b01c8e1fc31cad5c9fa6dc84.png

在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_USERS 的再次扫描。

外关联表消除

当进行外关联操作时,如果选择的字段都来自于左表,查询转换器可以消除该关联操作,消除对右表的扫描。

(以下示例在 11.2.0.1 中运行):

b95462d5f6417ed4a0d8c6ccbb06176c.png

cf84a4d5dbf3d4319bde22b8ec7298a3.png

在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_USERS 的扫描。

子查询合并(Subquery Coalesce)

子查询合并是 11g 中引入的新的查询重写技术。它是转换器在未对子查询做反嵌套的情况下,将两个兼容的子查询合并为一个子查询。

提示:子查询合并可以通过优化器参数"_optimizer_coalesce_subqueries"或提示NO_COALESCE_SQ/COALESCE_SQ 控制。

(以下示例在 11.2.0.1 中运行):

c22db95e28beba2545298617a4d94027.png

e0902000a9161f00a0783953221cff6c.png

在上例当中,子查询 SUB1 和 SBU2 被查询转换器融合了,它们的查询对象被直接关联。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值