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

相关文章

Oracle查询表结构建表语句索引等方式

《Oracle查询表结构建表语句索引等方式》使用USER_TAB_COLUMNS查询表结构可避免系统隐藏字段(如LISTUSER的CLOB与VARCHAR2同名字段),这些字段可能为dbms_lob.... 目录oracle查询表结构建表语句索引1.用“USER_TAB_COLUMNS”查询表结构2.用“a

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Kotlin Map映射转换问题小结

《KotlinMap映射转换问题小结》文章介绍了Kotlin集合转换的多种方法,包括map(一对一转换)、mapIndexed(带索引)、mapNotNull(过滤null)、mapKeys/map... 目录Kotlin 集合转换:map、mapIndexed、mapNotNull、mapKeys、map

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Oracle 数据库数据操作如何精通 INSERT, UPDATE, DELETE

《Oracle数据库数据操作如何精通INSERT,UPDATE,DELETE》在Oracle数据库中,对表内数据进行增加、修改和删除操作是通过数据操作语言来完成的,下面给大家介绍Oracle数... 目录思维导图一、插入数据 (INSERT)1.1 插入单行数据,指定所有列的值语法:1.2 插入单行数据,指

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实现编程