首页 数据库 mysql教程 Stored Outline存储提纲介绍

Stored Outline存储提纲介绍

Jun 07, 2016 pm 03:22 PM
out outline 介绍 存储

第一篇:outline是什么? outline设计来提供稳定的执行计划,以消除执行环境或对象统计信息的改变造成的影响。这个特性叫做计划稳定性。其实outline就是一堆hint的集合。 查询优化器接收到sql后,在选择是否使用OUTLINE时的逻辑。 a.对SQL语句进行标准化去除

第一篇:outline是什么? outline设计来提供稳定的执行计划,以消除执行环境或对象统计信息的改变造成的影响。这个特性叫做计划稳定性。其实outline就是一堆hint的集合。 查询优化器接收到sql后,在选择是否使用OUTLINE时的逻辑。 a.对SQL语句进行标准化去除空白大小写差异 b.计算签名 c.对比数据字典,看是否已存在一样的签名 d.如果是,再进一步比较sql语句是否相同(避免hash冲突) e.如果SQL一样,就可以将这个outline的相关hint收入郎中,以影响执行计划的生成了。
9i开始就可以用outline,但10g开始才可以从共享池的一个游标来手动创建outline。 要使用use_stored_outlines,必须开启use_stored_outlines参数 alter system set use_stored_outlines = test; 当一条SQL语句有sql profile又有outline时,查询优化器会有限选择outline。 何时使用: 每当调优一条特殊的SQL并且无法在应用程序里修改它时(比如,不能使用hint),就可以使用这项技术。但如果加了hint也不走一些执行计划,那用outline也木有用。 比如id列是varchar2(1)并且有索引,而sql用where to_number(id)=1,此时加了/*+index(t ind)*/也不走索引,用outline也无补于事。
第二篇:创建outline
1.自创创建outline ALTER [SESSION | SYSTEM] SET create_stored_outlines=TRUE|类别名; 例子:alter session set create_stored_outlines=fwy; --true模式的category是default 这个参数无法在参数文件指定,只能起库后再人工或触发器指定。

2.手动创建outline 2.1 基于文本 create or replace outline out_1 --for category test on select 3+8 from dual;
2.2.基于hash_value begin dbms_outln.create_outline( hash_value=>'1812086974', child_number =>0 -- category => 'test' ); end; /
第三篇:查询outline select * from dba_outlines where timestamp>sysdate-1/24;--过去一小时刚建的outline select * from dba_outlines where timestamp>sysdate-5/(24*60); --过去5分钟建的outline select hint from dba_outline_hints where name='OUTLINE_FROM_TEXT';--查询某个outline的hint集合
查看outline是否有被使用 1. 10gR2起,dbms_xplan函数看执行计划,会看到是否有使用Outline 2. 所有版本通行: execute dbms_outln.clear_used(name=> 'OUT_1'); --重置outline使用标记 select used from dba_outlines where name='OUT_1';--显示UNUSED 然后执行SQL select used from dba_outlines where name='OUT_1';--此时如果显示为used,则上述SQL有用到该OUTLINE了。

第四篇:更改OUTLINE --Rename outline alter outline SYS_OUTLINE_13090110433120101 rename to out2;
--更改单个outline的类别 alter outline out2 change category to default;
--更改多个outline类别,属于类别TEST的整体替换为类别default execute dbms_outln.update_by_cat(oldcat=>'TEST',newcat=>'DEFAULT');
--重建存储提纲 当你希望query optimizer根据新环境产生一个新的hint集合,可以使用它。比如改变了outline相关对象的访问结构时。 alter outline out_1 rebuild;
--query optimizer只考虑激活的outline,outline有两个条件符合才可以被激活 --第一,要处于enable状态。 创建时默认就是。如果不是可以通过以下语句做状态变换。 alter outline out_1 enable; alter outline out_1 disable; --第二,初始化参数use_stored_outlines在session级别或system级别激活。 true就是用default类别,false就是不用outline,或者某个类别名。 alter session set use_stored_outlines=true; alter system set use_stored_outlines=true; --这个参数一次只能激活一个类别,也就是跟sql profile一样,一个会话一次只能用一个类别。 十分奇怪的是,这个参数无法在pfile或者spfile中设置,只能实例系统后再设置。也可以借助触发器完成。

第五篇:移动outline --------------------------------------- vi exp.par userid="/ as sysdba" file=exp01.dmp log=exp_outline.log tables=(outln.ol$,outln.ol$hints,outln.ol$nodes) query="where ol_name ='FWY_3'" ---------------------------------------------------- exp parfile=exp.par ------------------------------vi imp.par userid="/ as sysdba" file=exp01.dmp log=imp_outline.log full=y ignore=y -----------------------------imp parfile=imp.par
--移动单个outline或者单个类别,在上述基础上加上以下语句 query="where ol_name ='OUT_1'" query="where category='TEST'" 比如,如果一个给定的 SQL语句的执行计划使用了一个你本想避免的索引扫描,那么你可以在测试系统中删除索引,在那里生成一个Outline,然后再将其转移到生产环境。
第六篇:编辑outline 想要编辑outline里面的hint,对数据字典中的公有outline用一些普通的SQL进行update是不行的,而对私有outline进行编辑是可行的。私有outline是存储在工作表中的,经过创建、编辑、测试后,我们可以将私有outline发布成公有outline。
1创建的两种方法 1.1. create or replace private outline out_3 on select * from dual; 1.2 create private outline p_out_1 from public out_1;
--10g后,默认工作表就是在system用户下的ol$,ol$hints,ol$nodes,还有默认的三个公共同义词指向它们。对于这三个表,在outln中也是有的,这才是作为公有的outline而存在的表。 如果用9i,就要手动创建工作表与公共同义词。 sqlplus '/as sysdba' alter session set current_schema=system; execute dbms_outln_edit.create_edit_tables;
create or replace public synonym ol$ for system.ol$;
create or replace public synonym ol$hints for system.ol$hints; create or replace public synonym ol$nodes for system. ol$nodes ;
grant select,insert,update,delete on system.ol$ to public; grant select,insert,update,delete on system.ol$hints to public; grant select,insert,update,delete on system.ol$nodes to public;
一旦私有outline创建完毕,就可以列出私有outline相关的Hint select hint#,hint_text from system.ol$hints where ol_name='OUT_4';
--然后用普通的sql语句可以更新它的hint --本来HINT#的1的hint_text是 INDEX(@"SEL$1" "T"@"SEL$1" ("T"."N")) --现在要变成走全表扫描 update ol$hints set hint_text='FULL(@SEL$1 T)' where hint#=1 and ol_name='P_OUTLINE_EDITING'; --为了确保这个outline在内存中的副本也同步进行了更改,执行如下 execute dbms_outln_edit.refresh_private_outline('OUT_1') --接着,激活并测试这个private outline. alter session set use_private_outlines =true; explain plan for select * from t where n=1970; select * from table(dbms_xplan.display(null,null,'basic +note)')); --如果对private outline满意,就可以使用下面这个sql将它发布成public outline. create public outline out_1 from private p_out_1;
第七篇 删除存储提纲 删除单个 drop outline out_1; 删除整类别 dbms_outln.drop_by_cat(cat=>'TEST'); 删除私有提纲 drop private outline out_1;
第八篇:OUTLINE互换 --将BEFORE与AFTER两个outline互换 UPDATE OUTLN.OL$HINTS SET OL_NAME=DECODE(OL_NAME,'AFTER','BEFORE','BEFORE','AFTER') WHERE OL_NAME IN ('AFTER','BEFORE');

 

exec dbms_outln.update_signatures; --更新签名

drop outline after;--更换完后,可以将不用的outline删除

 

第九篇:其他事项 在10gr1之前,outline是不能覆盖初始化参数,为了成功用outline,这几个初始化参数要与执行化境设置保持一致才可以噢。 optimizer_features_enable query_rewrite_enabled star_transformation_enabled
A用户创建的outline,B用户也可以用,不用授权。 OUTLINE在RAC环境下,每个实例都需要开启使用参数,才能用OUTLINE。

 

 


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

wapi是什么东西详细介绍 wapi是什么东西详细介绍 Jan 07, 2024 pm 09:14 PM

wapi这个名词用户们可能在使用网络得时候见到过,但是对于一部分人来说肯定都不知道wapi是什么,下面就带来了详细介绍,帮助不知道小伙伴去了解。wapi是什么东西:答:wapi是无线局域网鉴别和保密的基础结构。这就像红外线和蓝牙等功能一样,一般都覆盖在办公楼等地方的附近。基本都是为一个小部门所有的,所以这个功能涉及的范围只有几公里。wapi相关介绍:1、wapi是无线局域网里面的一种传输协议。2、这款技术是可以去避免窄频带通信的问题,可以更好的去进行传播。3、仅仅只需要一个代码就可以去传送信号了

详解win11能否运行PUBG游戏 详解win11能否运行PUBG游戏 Jan 06, 2024 pm 07:17 PM

pubg又称绝地求生,是一款非常经典的射击大逃杀类型游戏,从2016年火爆以来一直拥有非常多的玩家。在最近的win11系统推出后,就有不少玩家想要在win11上游玩它,下面就跟着小编来看看win11是否可以玩pubg吧。win11能玩pubg吗:答:win11可以玩pubg。1、在win11推出之初,因为win11需要开启tpm的缘故,所以导致很多玩家被pubg封号处理了。2、不过后来根据玩家的反馈,蓝洞方面已经解决了这个问题,目前已经可以在win11中正常玩pubg了。3、如果大家遇到了pub

华为明年将推创新 MED 存储产品:机架容量超过 10 PB,功耗低于 2 kW 华为明年将推创新 MED 存储产品:机架容量超过 10 PB,功耗低于 2 kW Mar 07, 2024 pm 10:43 PM

本站3月7日消息,华为数据存储产品线总裁周跃峰博士日前出席MWC2024大会,专门展示了为温数据(WarmData)和冷数据(ColdData)设计的新一代OceanStorArctic磁电存储解决方案。华为数据存储产品线总裁周跃峰发布系列创新解决方案图源:华为本站附上华为官方新闻稿内容如下:该方案的成本比磁带低20%,功耗比硬盘低90%。根据国外科技媒体blocksandfiles报道,华为发言人还透露了关于该磁电存储解决方案的信息:华为的磁电磁盘(MED)是对磁存储介质的重大创新。第一代ME

Python函数介绍:exec函数的介绍及示例 Python函数介绍:exec函数的介绍及示例 Nov 03, 2023 pm 02:09 PM

Python函数介绍:exec函数的介绍及示例引言:在Python中,exec是一种内置函数,它用于执行存储在字符串或文件中的Python代码。exec函数提供了一种动态执行代码的方式,使得程序可以在运行时根据需要生成、修改和执行代码。本文将介绍exec函数的使用方法,并给出一些实际的代码示例。exec函数的使用方法:exec函数的基本语法如下所示:exec

主板上的数字音频输出接口-SPDIF OUT 主板上的数字音频输出接口-SPDIF OUT Jan 14, 2024 pm 04:42 PM

主板上SPDIFOUT连接线序最近我遇到了一个问题,就是关于电线的接线顺序。我上网查了一下,有些资料说1、2、4对应的是out、+5V、接地;而另一些资料则说1、2、4对应的是out、接地、+5V。最好的办法是查看你的主板说明书,如果找不到说明书,你可以使用万用表进行测量。首先找到接地,然后就可以确定其他的接线顺序了。主板vdg怎么接线连接主板的VDG接线时,您需要将VGA连接线的一端插入显示器的VGA接口,另一端插入电脑的显卡VGA接口。请注意,不要将其插入主板的VGA接口。完成连接后,您可以

i5处理器是否能装win11详细介绍 i5处理器是否能装win11详细介绍 Dec 27, 2023 pm 05:03 PM

i5是英特尔旗下的一系列处理器,拥有到现在11代i5的各种不同版本,每一代都有着不同性能。因此对于i5处理器是否能够安装win11,还需要看是第几代的处理器,下面就跟着小编一起来分别了解一下吧。i5处理器能装win11吗:答:i5处理器能装win11。一、第八代及之后的i51、第八代及后续的i5处理器是能够满足微软的最低配置需求的。2、因此我们只需要进入微软网站,下载一个“win11安装助手”3、下载完成后,运行该安装助手,根据提示进行操作就可以安装win11了。二、第八代之前的i51、第八代之

介绍最新的Win 11声音调法方法 介绍最新的Win 11声音调法方法 Jan 08, 2024 pm 06:41 PM

很多用户更新了最新的win11之后发现自己系统的声音有了些许的变化,但是又不知道该怎么去进行调整,所以今天本站就给你们带来了电脑最新win11声音调法介绍,操作不难而且选择多样,快来一起下载试试吧。电脑最新系统windows11声音如何调1、首先右击桌面右下角的声音图标,并选择“播放设置”。2、然后进入设置中点击播放栏中的“扬声器”。3、随后点击右下方的“属性”。4、点击属性中的“增强”选项栏。5、此时如果“禁用所有声音效果”前的√勾上了就把他取消。6、之后就可以选择下面的声音效果来进行设置并点

PyCharm新手指南:替换功能全面解析 PyCharm新手指南:替换功能全面解析 Feb 25, 2024 am 11:15 AM

PyCharm是一款功能强大的Python集成开发环境,具有丰富的功能和工具,能够极大地提高开发效率。其中,替换功能是开发过程中经常用到的功能之一,能够帮助开发者快速修改代码并提高代码质量。本文将详细介绍PyCharm的替换功能,并结合具体的代码示例,帮助新手更好地掌握和使用该功能。替换功能简介PyCharm的替换功能可以帮助开发者在代码中快速替换指定的文本

See all articles