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

2023-10-22 02:50

本文主要是介绍星形转换 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 被查询转换器融合了,它们的查询对象被直接关联。

这篇关于星形转换 oracle,星型转换(Star Transformation)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/258636

相关文章

详解如何通过Python批量转换图片为PDF

《详解如何通过Python批量转换图片为PDF》:本文主要介绍如何基于Python+Tkinter开发的图片批量转PDF工具,可以支持批量添加图片,拖拽等操作,感兴趣的小伙伴可以参考一下... 目录1. 概述2. 功能亮点2.1 主要功能2.2 界面设计3. 使用指南3.1 运行环境3.2 使用步骤4. 核

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

C语言中的数据类型强制转换

《C语言中的数据类型强制转换》:本文主要介绍C语言中的数据类型强制转换方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C语言数据类型强制转换自动转换强制转换类型总结C语言数据类型强制转换强制类型转换:是通过类型转换运算来实现的,主要的数据类型转换分为自动转换

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

Java实现XML与JSON的互相转换详解

《Java实现XML与JSON的互相转换详解》这篇文章主要为大家详细介绍了如何使用Java实现XML与JSON的互相转换,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. XML转jsON1.1 代码目的1.2 代码实现2. JSON转XML3. JSON转XML并输出成指定的