固定执行计划-测试步骤

2024-03-06 22:28

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

0、环境准备,由于t有索引,该语句默认走索引

如果抓取优化参数未开启,也无法抓取

optimizer_capture_sql_plan_baselines boolean TRUE

alter system set optimizer_capture_sql_plan_baselines =true scope=both;

select count(*) from t where user_id=75;

select sql_id,PLAN_HASH_VALUE,sql_text from v$sql where sql_text like '%user_id=75%';

SQL_ID:84aytmtdzdh0j

PLAN_HASH_VALUE:878720519

1、创建指定SQLID的BASELINE,后面要做修改

declare

l_pls number;

begin

l_pls := DBMS_SPM.LOAD_PLANS_FROM_CURSOR_CACHE(

sql_id => '84aytmtdzdh0j',

plan_hash_value => 878720519,

enabled => 'NO');

end;

/

select count(*) from t where user_id=75;

2、构造出执行计划为全表扫描的SQL_ID,即:正确的执行计划

select /*+ full(t) */count(*) from t where user_id=75;

select sql_id,PLAN_HASH_VALUE,sql_text from v$sql where sql_text like '%user_id=75%';

SQL_ID:0pvkzjqwdgkbt

PLAN_HASH_VALUE:2966233522

3、确定原始执行计划的 sql_handle

select sql_handle, plan_name, origin, enabled, accepted,fixed,optimizer_cost,sql_text from dba_sql_plan_baselines where sql_text like '%user_id=75%' order by last_modified;

SQL_HANDLE:SQL_17ff9d394b036628

PLAN_NAME:SQL_PLAN_1gzwx755h6tj8fa7e82c5

4、与正确的执行计划关联

declare l_pls number;

begin

l_pls := DBMS_SPM.load_plans_from_cursor_cache(sql_id => '0pvkzjqwdgkbt', --正确执行计划的sql_id

plan_hash_value =>2966233522, --正确执行计划的plan_hash_value

sql_handle => 'SQL_17ff9d394b036628' --原执行计划的sql_handle

);

end;

/

5、删除错误执行计划(可选)

declare l_pls number;

begin

l_pls := DBMS_SPM.DROP_SQL_PLAN_BASELINE(sql_handle => 'SQL_17ff9d394b036628', --sql_handle_for_original

plan_name => 'SQL_PLAN_1gzwx755h6tj8fa7e82c5' --sql_plan_name_for_original

);

end;

/

6、验证

explain plan for select count(*) from t where user_id=75;

select * from table(dbms_xplan.display);

7、(其他)查询所有执行计划

select * from table(dbms_xplan.display_cursor('sql_id',NULL,'OUTLINE'));

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


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

相关文章

解密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(推

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序

SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法

《SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法》在SQLyog中执行存储过程时出现的前置缩进问题,实际上反映了SQLyog对SQL语句解析的一个特殊行为,本文给大家介绍了详... 目录问题根源正确写法示例永久解决方案为什么命令行不受影响?最佳实践建议问题根源SQLyog的语句分

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at