绑定运行计划sql_plan_baseline[通俗易懂]

绑定运行计划sql_plan_baseline

大家好,又见面了,我是全栈君。

–因为生产环境运行的sql变化较快,版本号公布比較频繁,造成sql的运行计划不是非常稳定。常常会有一些性能非常查的sql出现
–对于这些sql,我们能够使用sql_plan_baseline对运行计划进行绑定,从而使运行计划固定下来
–前提是sql最好使用绑定变量。就算有的没有绑定变量,确定字段的值不会改变才行。由于是针对sql_id进行的绑定,假设sql文本改变,绑定也就无意义了

详细步骤:
–1、找到问题sql,假设查询sql的运行计划,假设有合适的运行计划。直接进行绑定
–查询sql运行计划相应的PLAN_HASH_VALUE
SELECT DISTINCT(PLAN_HASH_VALUE) FROM V$SQL_PLAN t WHERE SQL_ID = ‘010cv4dvf6swv’ and child_number=’0′
–绑定好的运行计划:
declare
  l_pls number;
begin
  l_pls := DBMS_SPM.LOAD_PLANS_FROM_CURSOR_CACHE(sql_id  => ‘524wzct86gu1d’,
                                                 plan_hash_value => 2554538542,
                                                 enabled         => ‘YES’);
end;
/

2、假设没有合适的运行计划,就要通过自己分析,运用一些hint让sql产生比較好的运行计划
–须要绑定的sql
–oldSQL(id PLAN_HASH_VALUE)
524wzct86gu1d
2554538542

–新的sql
–newSQL(id PLAN_HASH_VALUE)
010cv4dvf6swv
756701203
–查询新的运行计划的sql_id
select * from v$sql where sql_text like ‘%zhruoyu%’ –通过在hint中加一下特殊字符来查找

—新建制定SQLID的BASELINE依据old_sql id,PLAN_HASH_VALUE
declare
  l_pls number;
begin
  l_pls := DBMS_SPM.LOAD_PLANS_FROM_CURSOR_CACHE(sql_id    => ‘524wzct86gu1d’,
                                                 plan_hash_value => 2554538542,
                                                 enabled         => ‘NO’);  –注意这里是no
end;
/

—确定原始运行计划的 sql_handle
select sql_handle, plan_name, origin, enabled, accepted,fixed,creator,optimizer_cost,sql_text
from dba_sql_plan_baselines where origin = ‘MANUAL-LOAD’ order by created desc
 
SQL_HANDLE:SQL_66108ad9595208fc                                     
PLAN_NAME:SQL_PLAN_6c44av5cp427w65e519aa

—与正确的运行计划做关联
declare
  l_pls number;
begin
  l_pls := DBMS_SPM.load_plans_from_cursor_cache(sql_id          => ‘010cv4dvf6swv’, — new_SQL_ID’
                                                 plan_hash_value => 756701203, –new_plan_hash_value
                                                 sql_handle      => ‘SQL_66108ad9595208fc’ –OLD_handle
                                                 );
end;
/

—删除错误的运行计划
declare
  l_pls number;
begin
  l_pls := DBMS_SPM.DROP_SQL_PLAN_BASELINE(sql_handle => ‘SQL_66108ad9595208fc’, –sql_handle_for_original
                                           plan_name  => ‘SQL_PLAN_6c44av5cp427w65e519aa’ –sql_plan_name_for_original                                       
                                           );
end;
/

–检查一下
select sql_handle, plan_name, origin, enabled, accepted,fixed,creator,optimizer_cost,sql_text
from dba_sql_plan_baselines where origin = ‘MANUAL-LOAD’ and sql_handle=’SQL_66108ad9595208fc’

–完毕

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116257.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月23日 下午10:00
下一篇 2022年1月23日 下午10:00


相关推荐

  • electron调用go_opencv scalar

    electron调用go_opencv scalarglub一般都是很轻量的编译。go太重了,改一小个部分,就编译的话,多数是编译失败。而且很消耗性能,还没想到完美的优化办法。暂时用个定时器监听2秒,停止1秒,如此循环,会减少些“无效”的编译varwatch=require(‘glob-watcher’);varexec=require(‘child_process’).exec;varsys…

    2025年7月28日
    3
  • c语言交通灯简单编程_在第一个交通灯处左转的英文

    c语言交通灯简单编程_在第一个交通灯处左转的英文内容介绍原文档由会员½ӨӨ发布交通灯控制系统设计1万字32页包括程序代码,系统原理图,Proteus仿真过程摘要本设计是交通信号灯控制系统,随着社会的不断的进步,社会的不断发展。交通也日渐复杂,交通的自动化也不断更新,交通的一些指挥系统光靠人来完成是远远不够的,这就需要设计各种交通指挥自动化系统来完成这些复杂的工作。从而使交通指挥系统更加有秩序,更加安全。至此本人设计了交通信号灯控制系统,来…

    2025年12月5日
    4
  • IDEA 安装 Lombok 插件

    IDEA 安装 Lombok 插件

    2021年7月11日
    125
  • 多端发力落地“小龙虾”,联想百应×OpenClaw数字员工解决方案激活成功教程安全痛点

    多端发力落地“小龙虾”,联想百应×OpenClaw数字员工解决方案激活成功教程安全痛点

    2026年3月13日
    2
  • Adb连接android设备的2种方法!!!!

    Adb连接android设备的2种方法!!!!第一种 USB 连接 最简单的方式 安卓手机打开开发者模式 启用 usb 调试 CMD 窗口输入 adbdevices 就可以看到连接的设备了第二种 Wifi 连接安卓机和电脑都在同一局域网内 CMD 窗口输入 adbconnect 安卓机 ip 地址如果提示 unabletoconn 安卓机 ip 地址 5555 解决方法 3 1 使用 usb 线接连安卓机 启动端口监听 端口监听命令 adbtcpip5555 如果提示 说明手机上有需要我们手动确认的对话框 点击确认就好了 然后再

    2026年3月18日
    2
  • Java中 String 转 Long 类型需要注意的事项

    Java中 String 转 Long 类型需要注意的事项Java 中 String 转 Long 类型需要注意的事项注意事项 1 字符串内不能包含除数字之外的字符不然会报错 java lang NumberFormat 字符串长度要限制 不然也会出错比如 Strings 超过 19 位 就会出错 报 java lang NumberFormat 不超过 19 位就不会原因是 Long 类型的最大值位 Long MAX

    2026年3月18日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号