星形转换 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

相关文章

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr

Java如何将文件内容转换为MD5哈希值

《Java如何将文件内容转换为MD5哈希值》:本文主要介绍Java如何将文件内容转换为MD5哈希值的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java文件内容转换为MD5哈希值一个完整的Java示例代码代码解释注意事项总结Java文件内容转换为MD5

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Java实现视频格式转换的完整指南

《Java实现视频格式转换的完整指南》在Java中实现视频格式的转换,通常需要借助第三方工具或库,因为视频的编解码操作复杂且性能需求较高,以下是实现视频格式转换的常用方法和步骤,需要的朋友可以参考下... 目录核心思路方法一:通过调用 FFmpeg 命令步骤示例代码说明优点方法二:使用 Jaffree(FF

C语言中的常见进制转换详解(从二进制到十六进制)

《C语言中的常见进制转换详解(从二进制到十六进制)》进制转换是计算机编程中的一个常见任务,特别是在处理低级别的数据操作时,C语言作为一门底层编程语言,在进制转换方面提供了灵活的操作方式,今天,我们将深... 目录1、进制基础2、C语言中的进制转换2.1 从十进制转换为其他进制十进制转二进制十进制转八进制十进