利用outline固定执行计划

2024-05-13 02:58
文章标签 执行 计划 固定 outline

本文主要是介绍利用outline固定执行计划,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

登录scott创建实验用表TEST1:create table test1 (name varchar2(10));
插入数据:insert into test1 values('luyang'); 
 insert into test1(name) values('zhengda');
          insert into test1(name) values('sunyi');
 insert into test1(name) values('lixuefei');
 




1、管理员用户授权
grant create any outline to scott;




2、登录scott用户创建outline
create or replace outline TEST1_OUTLINE
for category demo on
select * from test1 where name='luyang';




3、查看概要是否生成
COL NAME FOR A30
COL CATEGORY FOR A10
COL SQL_TEXT FOR A30
select name, category, used, sql_text
from user_outlines
where category = 'DEMO';


NAME                           CATEGORY   USED   SQL_TEXT
------------------------------ ---------- ------ ------------------------------
TEST1_OUTLINE                  DEMO       UNUSED select * from test1 where name
                                                 ='luyang'


4、修改OUTLN用户密码、解锁
alter user outln account unlock identified by outln;




5、使用outln用户,exp导出outline的数据
exp outln/outln tables=OL\$,OL\$HINTS file=ol.dmp log=ol.log






以上是在我的10G库上的操作
*********************************************************************************************************
以下是在我的11G库上的操作




6、使用outln用户,导入outline数据
imp outln/outln file=c:\ol.dmp ignore=y log=c:\ol.log;






7、使用sys用户更新outline的signature
exec dbms_outln.update_signatures;
启用stored outline
alter system set use_stored_outlines=demo; 




8、检查outlines是否被使用
conn scott/tiger
create index ind_test1 on test1(name);
set autotrace trace explain;
select * from test1 where name='luyang';


Execution Plan
----------------------------------------------------------
Plan hash value: 4122059633


---------------------------------------------------------------------------
| Id  | Operation         | Name  | Rows  | Bytes | Cost (%CPU)| Time     |
---------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |       |     1 |     7 |     3   (0)| 00:00:01 |
|*  1 |  TABLE ACCESS FULL| TEST1 |     1 |     7 |     3   (0)| 00:00:01 |
---------------------------------------------------------------------------


Predicate Information (identified by operation id):
---------------------------------------------------


   1 - filter("NAME"='luyang')


Note
-----
   - outline "TEST1_OUTLINE" used for this statement


注意执行计划指出online已经使用
说明outline已经启用。


























停止db使用outline功能: 
alter system set use_stored_outlines=false; 




注意:outline固定执行计划只能针对固定的sql语句,如果上面试验你用select * from scott.test1 where name='luyang';也不会走outline的!















这篇关于利用outline固定执行计划的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

解密SQL查询语句执行的过程

《解密SQL查询语句执行的过程》文章讲解了SQL语句的执行流程,涵盖解析、优化、执行三个核心阶段,并介绍执行计划查看方法EXPLAIN,同时提出性能优化技巧如合理使用索引、避免SELECT*、JOIN... 目录1. SQL语句的基本结构2. SQL语句的执行过程3. SQL语句的执行计划4. 常见的性能优

Spring Bean初始化及@PostConstruc执行顺序示例详解

《SpringBean初始化及@PostConstruc执行顺序示例详解》本文给大家介绍SpringBean初始化及@PostConstruc执行顺序,本文通过实例代码给大家介绍的非常详细,对大家的... 目录1. Bean初始化执行顺序2. 成员变量初始化顺序2.1 普通Java类(非Spring环境)(

Spring Boot 中的默认异常处理机制及执行流程

《SpringBoot中的默认异常处理机制及执行流程》SpringBoot内置BasicErrorController,自动处理异常并生成HTML/JSON响应,支持自定义错误路径、配置及扩展,如... 目录Spring Boot 异常处理机制详解默认错误页面功能自动异常转换机制错误属性配置选项默认错误处理

如何在Java Spring实现异步执行(详细篇)

《如何在JavaSpring实现异步执行(详细篇)》Spring框架通过@Async、Executor等实现异步执行,提升系统性能与响应速度,支持自定义线程池管理并发,本文给大家介绍如何在Sprin... 目录前言1. 使用 @Async 实现异步执行1.1 启用异步执行支持1.2 创建异步方法1.3 调用

Spring Boot Maven 插件如何构建可执行 JAR 的核心配置

《SpringBootMaven插件如何构建可执行JAR的核心配置》SpringBoot核心Maven插件,用于生成可执行JAR/WAR,内置服务器简化部署,支持热部署、多环境配置及依赖管理... 目录前言一、插件的核心功能与目标1.1 插件的定位1.2 插件的 Goals(目标)1.3 插件定位1.4 核

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推