本文主要是介绍星形转换 oracle,星型转换(Star Transformation),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
所谓星型查询(Star Query),是指一个事实表(Fact Table)与多个维度表(Dimension Table) 的关联查询,并且维度表仅与事实表之间关联,维度表之间不存在关联关系。星型查询分为两个阶段:
•第一阶段是由事实表利用位图索引的位图信息(或者由 B*树索引的 ROWID 转换得来的位图信息)进行位图操作,进而获得相应数据集;
•第二阶段则将第一阶段获得的数据集与维度表进行关联,获取最终查询结果。星型转换即将事实表与多个维度表的普通关联查询转换为星型查询的一项优化技术。
提示:星型转换可以由参数 star_transformation_enabled 或者提示STAR_TRANSFORMATION/NO_STAR_TRANSFORMATION 控制
排序消除(Order By Elimination,OBYE)
排序消除,是指优化器在生成执行计划之前,将语句中没有必要排序操作消除掉,从而避免在 执行计划中出现排序操作或由排序导致的操作(如 Index Full Scan)。
提示:排序消除可以由优化器参数_optimizer_order_by_elimination_enabled 或者提示ELIMINATE_OBY/NO_ELIMINATE_OBY 控制。
Distinct 消除(Distinct Elimination)
根据表中主键、唯一约束信息,消除查询语句中的 DISTINCT。这是一项启发式的查询转换。
上例中,尽管在 SELECT 子句中存在 DISTINCT 关键字,但由于表上存在唯一性约束T_USERS_UK(USERNAME),但并它没有增加 SORT/HASH UNIQUE 操作来消除重复值。
表消除(Table Elimination)
表消除是查询转换器依据表之间的主外键关系、位图关联索引等信息,将复杂查询语句中不必要的读取的表消除掉的一项优化技术。由于表消除出现在连接查询语句里面,因此也称为连接消除(Join Elimination,JE)。
提示:表消除可以由优化器参数"_optimizer_join_elimination_enabled"和提示ELIMINATE_JOIN/NO_ELIMINATE_JOIN 控制。
主外键关系消除关联操作
查询转换器能够依据两表之间的主外键关系消除关联操作,消除对关联表的扫描。
在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_TABLESPACES 的扫描。
位图关联索引消除关联操作
查询转换器能够依据建立在主表上指向引用表的位图关联索引(Bitmap Join Index)来消除关联操作,消除对关联表的扫描。
(以下示例在 11.2.0.1 中运行):
在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_USERS 的再次扫描。
外关联表消除
当进行外关联操作时,如果选择的字段都来自于左表,查询转换器可以消除该关联操作,消除对右表的扫描。
(以下示例在 11.2.0.1 中运行):
在上例中,由于消除了关联操作,在最终的执行计划中没有出现对表 T_USERS 的扫描。
子查询合并(Subquery Coalesce)
子查询合并是 11g 中引入的新的查询重写技术。它是转换器在未对子查询做反嵌套的情况下,将两个兼容的子查询合并为一个子查询。
提示:子查询合并可以通过优化器参数"_optimizer_coalesce_subqueries"或提示NO_COALESCE_SQ/COALESCE_SQ 控制。
(以下示例在 11.2.0.1 中运行):
在上例当中,子查询 SUB1 和 SBU2 被查询转换器融合了,它们的查询对象被直接关联。
这篇关于星形转换 oracle,星型转换(Star Transformation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!