Oracle复习部分记录

GuassDB,Oracle,Postgresql 适用的hint说明

一、在使用with as 短语时,使用materialize 会生产临时表,执行完成后,PGA会将其清除。
materialize

二、pq_distribute 表示在并行过程中,按照并行对标划分多少个分区,a分区与b分区如何进行关联并行查询。可能是a广播到b的每个分区进行关联合并。
详细说明URL:https://www.cnblogs.com/kakaisgood/p/13181352.html
use_hash(a,b) parallel(a,6),parallel(b,6) pq_distribute

三、指定优化器使用的表的索引
index(tablename index_name)
alter session set ‘_optimizer_push_pred_cost_based’=false 禁止谓词推入
alter session set ‘_push_join_predicate’=false 禁止非常量的谓词推入

四、关闭位图索引转换
alter session set ‘_b_tree_bitmap_plans’=false
/+ opt_param(‘_b_tree_bitmap_plans’,‘false’)/

五、dblink 同时查询本地表与远程表,两种处理方式:第一种是将远程数据表数据取回本地,然后跟本地表进行关联查询,获取最终结果。第二种是将本地表数据传到远程库中与远程表进行关联查询,在将关联结果取回。r便是remote的表名称,l表示local的表名称
主要用于减少网络传输,但是对与DDL,DML driving_sit()的hint的提示是无效的。

driving_sit® #如果本地表数据量较小,则用r代替远程的表名称,表示将本地表数据通过网络传输到远程库表中进行关联后,获取最终结果集。

driving_sit(l) #如果远程表数据量较小,则用l代替本地的表名称,表示将远程表数据通过网络传输到本地库表中进行关联查询。

六、禁用笛卡尔积连接,使用use_hash() 指定连接表之间的where条件通过hash值进行匹配关联
use_hash(a,b) opt_param(‘_optimizer_mjc_enabled’,‘false’)

七、视图合并
merge() 存在A,B,C。B与C组成视图,然后A跟BC视图进行结果集关联。如果进行视图合并,则根据where条件,可能会出现AB进行先关联,做HASH JOIN操作,然后结果集与C进行关联。可能在执行计划中,不会出现view的字样。
no_merge() 存在A,B,C。B与C组成视图,然后A跟BC视图进行结果集关联。

八、延迟进行聚合运算
lazyagg 在子查询中有group by 且外部还存在group by的情况下,子查询中的表很大,外部的表相比较小的情况下。使用该特性,会消除子查询中的聚合运算,先关联在group by。

九、配合leading() 指定d为被驱动表,e为驱动表。指定优化器将我们指定的多个表作为被驱动表与其它表或结果集或排序合并连接
use_merge(e,d) leading(d) index(d) index(e index_name)
禁止笛卡尔积
opt_param(‘_optimizer_mjc_enabled’,false)

十、存在nesting loop的情况下,进一步控制表关联的顺序,leading(emp)先对emp表进行查询并与dept先进行关联操作
use_nl(emp,dept) leading(emp)

十一、将主查询表中的where条件下推到where子查询,相当于通过主查询表中的where条件减少了子查询中的扫描行数。如果A.r=1 and (A join B),则可能存在先A.r=1 与(AjoinB)的结果集进行聚合。magicset则先A.r=1减少结果集后,在进行(AjoinB),进一步减少数据集,采用递归的方式最后得出结果。
magicset

十二、将where,having非相关子查询提升和winmagic重写优化,相当于将子查询提升为join等方式
enable_sublink_pullup_enhanced

十三、将标量子查询改成为left join 标量子查询是指只返回一行一列的查询
Intargetlist

十四、谓词推入,将条件推入到子查询中,将过滤条件尽早的推入到子查询中,减少内部查询返回的数据量
predpushnormal,predpush,predpushforce

十五、禁止子查询提升,相当于对子查询加/+no_expand/
disable_pullup_expr_sublink

十六、提升无agg的where子查询,表示没有agg聚合函数(比如 sum函数)的子查询,指示优化器对子查询的条件进行唯一值校验,保证对于每个条件只有一行输出
uniquecheck

十七、消除where子查询中的distinct和group by
remove_redundant_distinct_group_by

十八、列裁剪消除子查询中冗余的投影列,只保留在查询过程中处理的有效数据列(被需要关联的列),减少I/O操作和内存的使用
column_pruner

十九、子查询展开
semi-join 半连接
anti-join 反连接
unnest与nounnest
nounnest 子查询不展开的意思是当子查询在最后一步执行,对应执行计划为FILTER,过滤的方式进行匹配。
unnest 子查询展开的意思是会将子查询里面的整体结果集和外部的表做hash join或HASH JOIN SEMI的连接。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28487.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

0118__C语言——float.h文件

C语言——float.h文件_c float.h-CSDN博客

React 中的事件处理

React 中是如何处理事件的&#xff0c;现在下面简单的一段代码&#xff1a; export default function App() {const AList lazy(()>import(./List.js))const r useRef(null) const [show, setShow] useState(false);return (<><button onFocus{()>{setShow…

【StructueEngineering】Wind Load Combination Patterns风荷载组合模式

文章目录 Combination PatternsBasic Rules of Combinations组合的基本规律Specific Combination Patterns1. First 8 Combinations (1 to 8)2. Middle 8 Combinations (9 to 16)3. Last 8 Combinations (17 to 24) Summary of CombinationsKey Variables and Parameters with …

Postgre 调优工具pgBadger部署

一&#xff0c;简介&#xff1a; pgBadger&#xff08;日志分析器&#xff09;类似于oracle的AWR报告&#xff08;基于1小时&#xff0c;一天&#xff0c;一周&#xff0c;一月的报告&#xff09;&#xff0c;以图形化的方式帮助DBA更方便的找到隐含问题。 pgbadger是为了提高…

轻松上手MYSQL:探索MySQL索引数据结构的奥秘-让数据库飞起来

​&#x1f308; 个人主页&#xff1a;danci_&#x1f525; 系列专栏&#xff1a;《设计模式》《MYSQL》&#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 ✨欢迎加入探索MYSQL索引数据结构之旅✨ &#x1f44b; 大家好&#xff01;文本学习研…

代理IP协议有何区别?深入了解 SOCKS5、HTTP 代理

在数字通信领域&#xff0c;数据安全和匿名性都是非常重要的指标。互联网的不断发展催生了几种协议&#xff0c;每种协议都有独特的优势和挑战。其中&#xff0c;SOCKS5 代理、HTTP代理最为广泛使用&#xff0c;下面给大家一起讨论&#xff0c;HTTP代理与 SOCKS5代理&#xff0…

【技术】JS 操作剪贴板

JS 操作剪贴板 1、原生 JS 操作剪贴板复制文本2、原生 JS 操作剪贴板读取图片实现异步上传navigator 对象监听粘贴事件 3、剪贴板插件 1、原生 JS 操作剪贴板复制文本 在博客类网站看到一段代码&#xff0c;想复制&#xff0c;如果代码量比较大&#xff0c;选中内容复制会比较…

基于python深度学习的CNN图像识别鲜花-含数据集+pyqt界面

代码下载&#xff1a; https://download.csdn.net/download/qq_34904125/89383615 本代码是基于python pytorch环境安装的。 下载本代码后&#xff0c;有个requirement.txt文本&#xff0c;里面介绍了如何安装环境&#xff0c;环境需要自行配置。 或可直接参考下面博文进行…

WPF 使用Image控件显示图片

Source属性 Source属性用来告诉Image组件要展示哪张图片资源的一个入口&#xff0c;通常是图片的路径。也许是本地路径&#xff0c;也许是网络路径。 本地图片路径加载方式 使用相对路径&#xff0c;相对于工程目录的路径&#xff0c;当设置Width属性时&#xff0c;图片会等…

Linux:基础IO(二.缓冲区、模拟一下缓冲区、详细讲解文件系统)

上次介绍了&#xff1a;Linux&#xff1a;基础IO&#xff08;一.C语言文件接口与系统调用、默认打开的文件流、详解文件描述符与dup2系统调用&#xff09; 文章目录 1.缓冲区1.1概念1.2作用与意义 2.语言级别的缓冲区2.1刷新策略2.2具体在哪里2.3支持格式化 3.自己来模拟一下缓…

FFMpeg解复用流程

文章目录 解复用流程图复用器与解复用器小结 解复用流程图 流程图&#xff0c;如上图所示。 复用器与解复用器 复用器&#xff0c;就是视频流&#xff0c;音频流&#xff0c;字幕流&#xff0c;其他成分&#xff0c;按照一定规则组合成视频文件&#xff0c;视频文件可以是mp4…

Linux各目录的作用

Linux各目录的作用 目录作用~登录用户对应的目录.当前工作目录$PATH环境变量/根目录/boot启动Linux使用的文件&#xff0c;例如Linux内核&#xff0c;包括连接文件和镜像文件&#xff0c;&#xff08;删了就启动不了了&#xff09;/bin(/usr/bin,/usr/local/bin)Binary&#x…

如何在vector中插入和删除元素?

在C的std::vector中插入和删除元素通常使用其成员函数来完成。以下是如何在std::vector中插入和删除元素的示例&#xff1a; 插入元素 在末尾插入元素&#xff1a;使用push_back函数。 cpp复制代码 #include <vector> int main() { std::vector<int> v; v.push_…

实现贪吃蛇小游戏【简单版】

1. 贪吃蛇游戏设计与分析 1.1 地图 我们最终的贪吃蛇大纲要是这个样子&#xff0c;那我们的地图如何布置呢&#xff1f; 这里不得不讲⼀下控制台窗口的⼀些知识&#xff0c;如果想在控制台的窗口中指定位置输出信息&#xff0c;我们得知道该位置的坐标&#xff0c;所以首先介…

CPN Tools学习——从平面网构建分层 PN

1.先创建平面petri网 创建如下petri网&#xff1a; CPN ide创建petri网真的舒服很多&#xff0c;但是教程又是CPN Tools的&#xff0c;我的想法是看两个版本能不能互通&#xff0c;在前者创建&#xff0c;在后者运行学习。 新增定义&#xff1a; colset E unit with e; 但…

nginx全解

一、Nginx配置文件 1.1 主配置文件 主配置文件位置&#xff1a;nginx.conf tip&#xff1a;安装方式不同&#xff0c;路径不同 #主配置文件格式 ​ main block&#xff1a;主配置段&#xff0c;即全局配置段&#xff0c;对http,mail都有效 ​ #配置Nginx服务器的事件模块相…

深度学习 --- stanford cs231学习笔记三(卷积神经网络CNN)

卷积神经网络CNN 1&#xff0c;有效的利用了图像的空间信息/局部感受野 全连接神经网络中的神经是由铺平后的所有像素计算决定。 由于计算时是把图像的所有像素拉成了一条线&#xff0c;因此在拉伸的同时也损失了图像像素之间固有的空间信息。 卷积层中的神经只由5x5x3(假设fil…

57.Linux/Unix 系统编程手册(下) -- SOCKET : Unix domain

https://blog.51cto.com/u_15567199/5204540 【linux网络编程】容错处理文件 wrap.h、wrap.c_wx623c6c9. // 容错处理 wrap.h #ifndef _WRAP_H_ #define _WRAP_H_#include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <error.h> #i…

LViT: 语言与视觉Transformer在医学图像分割中的应用| 文献速递-深度学习结合医疗影像疾病诊断与病灶分割

Title 题目 LViT: Language Meets Vision Transformer in Medical Image Segmentatio LViT: 语言与视觉Transformer在医学图像分割中的应用 01 文献速递介绍 医学图像分割是医学图像分析中最关键的任务之一。在临床实践中&#xff0c;准确的分割可以帮助医生诊断疾病&…