返回顶部
首页 > 资讯 > 数据库 >Oracle利用coe_load_sql_profile脚本绑定执行计划
  • 824
分享到

Oracle利用coe_load_sql_profile脚本绑定执行计划

2024-04-02 19:04:59 824人浏览 安东尼
摘要

coe_load_sql_profile_v2.sql脚本利用的是profile原理,只是做了半自动的形式来使用,下面是测试过程。 coe_load_sql_profile_v2.txt

coe_load_sql_profile_v2.sql脚本利用的是profile原理,只是做了半自动的形式来使用,下面是测试过程。

Oracle利用coe_load_sql_profile脚本绑定执行计划 coe_load_sql_profile_v2.txt

创建环境,构建测试表:

SQL> create table t1 as select * from dba_objects where object_id is not null;


Table created.


SQL> alter table t1 modify object_id not null;


Table altered.


SQL> create index idx_t1_obj_id on t1(object_id);


Index created.


索引不存储null值


SQL> analyze table t1 compute statistics;


Table analyzed.


SQL> select count(*) from t1;


  COUNT(*)

----------

     87070


SQL> select * from table(dbms_xplan.display_cursor(null,0));


PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------------------------------------

SQL_ID 12c0v4my7dvr3, child number 0

-------------------------------------

select count(*) from t1


Plan hash value: 1657298618


-------------------------------------------------------------------------------------------------------

| Id  | Operation             | Name | Rows  | Cost (%CPU)| Time    |

-------------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT  |      |      |      54 (100)|      |

|   1 |  SORT AGGREGAT    |      |     1 |       |      |


PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------------------------------------

|   2 |   INDEX FAST FULL SCAN| IDX_T1_OBJ_ID | 87070 |    54 (0)| 00:00:01 |

-------------------------------------------------------------------------------



14 rows selected.

会发现是进行的索引快速扫描。


使用hint提示,强行走全表扫描,然后生成执行计划。

SQL> select count(*)from t1;


  COUNT(*)

----------------------

     87070


SQL> select * from table(dbms_xplan.display_cursor(null,0));


PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------------------------------------

SQL_ID 20pat9zfypprh, child number 0

-------------------------------------

select count(*)from t1


Plan hash value: 3724264953


-----------------------------------------------------------------------------------------------------

| Id  | Operation              | Name | Rows | Cost (%CPU)| Time   |

-----------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT   |  |  |    347 (100)|    |

|   1 |  SORT AGGREGATE    |  | 1|          |    |


PLAN_TABLE_OUTPUT

--------------------------------------------------------------------------------------------------------------

|   2 |   TABLE ACCESS FULL| T1   | 87070 |   347   (1)| 00:00:05 |

-------------------------------------------------------------------



14 rows selected.


SQL> @coe_load_sql_profile_v2.sql


Parameter 1:

SQL_ID (required)


Enter value for 1: 12c0v4my7dvr3



PLAN_HASH_VALUE AVG_ET_SECS

--------------- -----------

     1657298618        .141


Parameter 2:

PLAN_HASH_VALUE (required)


Enter value for 2: 3724264953


Values passed to coe_xfr_sql_profile:

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

SQL_ID       : "12c0v4my7dvr3"

PLAN_HASH_VALUE: "3724264953"


SQL>BEGIN

  2   IF :sql_text IS NULL THEN

  3    RaiSE_APPLICATION_ERROR(-20100, 'SQL_TEXT for SQL_ID &&sql_id. was not found in memory (gv$sqltext_with_newlines) or AWR (dba_hist_sqltext).');

  4   END IF;

  5  END;

  6  /

SQL>SET TERM OFF;

SQL>BEGIN

  2   IF :other_xml IS NULL THEN

  3    RAISE_APPLICATION_ERROR(-20101, 'PLAN for SQL_ID &&sql_id. and PHV &&plan_hash_value. was not found in memory (gv$sql_plan) or AWR (dba_hist_sql_plan).');

  4   END IF;

  5  END;

  6  /

SQL>SET TERM OFF;


Execute coe_xfr_sql_profile_12c0v4my7dvr3_3724264953.sql

on TARGET system in order to create a custom SQL Profile

with plan 3724264953 linked to adjusted sql_text.

.........省略


COE_XFR_SQL_PROFILE_12c0v4my7dvr3_3724264953 completed


COE_XFR_SQL_PROFILE completed.

SQL>explain plan for select count(*) from t1;


Explained.


SQL>select * from table(dbms_xplan.display());


PLAN_TABLE_OUTPUT

------------------------------------------------------------------------------------------

Plan hash value: 3724264953


-------------------------------------------------------------------

| Id  | Operation   | Name | Rows  | Cost (%CPU)| Time  |

-------------------------------------------------------------------

|   0 | SELECT STATEMENT   |  | 1 |   347   (1)| 00:00:05 |

|   1 |  SORT AGGREGATE    |  | 1 |       |  |

|   2 |   TABLE ACCESS FULL| T1   | 87070 |   347   (1)| 00:00:05 |

-------------------------------------------------------------------


Note


PLAN_TABLE_OUTPUT

------------------------------------------------------------------------------------------

-----

   - SQL profile "coe_12c0v4my7dvr3_3724264953" used for this statement


13 rows selected.


SQL> select name,cateGory,status,sql_text from dba_sql_profiles;


NAME           CATEGORY   STATUS    SQL_TEXT

------------------------------------------- --------------------- ---------------- ------------------------------

coe_12c0v4my7dvr3_3724264953   DEFAULT  ENABLED  select count(*) from t1


可以看到脚本coe_load_sql_profile_v2.sql将执行计划固定了。



您可能感兴趣的文档:

--结束END--

本文标题: Oracle利用coe_load_sql_profile脚本绑定执行计划

本文链接: https://lsjlt.com/news/49248.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle利用coe_load_sql_profile脚本绑定执行计划
    coe_load_sql_profile_v2.sql脚本利用的是profile原理,只是做了半自动的形式来使用,下面是测试过程。 coe_load_sql_profile_v2.txt ...
    99+
    2024-04-02
  • Oracle执行计划绑定
    有时我们查询 gv$sql可以看出同一个SQL不同子游标的一些运行细节: selet t.inst_id,t.sql_id,t.child_number,t.plan_hash_value,t.last_...
    99+
    2024-04-02
  • 执行计划绑定
    http://www.mamicode.com/info-detail-1943333.html 需要绑定SQL执行计划常见的几种情况: SQL执行计划突变,导致数据库性能下降,从历史执行计划找一个合理...
    99+
    2024-04-02
  • oracle 11gSPM手动绑定执行计划
    自动计划捕获: SQL> sho parameter OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES NAME     &...
    99+
    2024-04-02
  • oracle 固定执行计划
    ---chenjch ...
    99+
    2024-04-02
  • oracle sqlprofile 固定执行计划,并迁移执行计划
    sqlprofile固定执行计划 模拟10g 执行计划迁移至11g oracle数据库中,11g库用10g的执行计划,这里是把hint 全盘扫描的执行计划迁移  --1.准备阶段&nb...
    99+
    2024-04-02
  • Oracle中怎么固定执行计划
    这篇文章给大家介绍Oracle中怎么固定执行计划,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1.1  BLOG文档结构图 1.2  前言部分1.2.1 ...
    99+
    2024-04-02
  • linux计划任务执行脚本怎么写
    在Linux系统中,计划任务可以使用crontab命令来执行。以下是一个编写计划任务执行脚本的示例:1. 打开终端并输入以下命令创建...
    99+
    2023-09-21
    linux
  • Oracle DB 相关常用sql汇总7【手工绑定sql执行计划】
    SPO coe_xfr_sql_profile.log; SET DEF ON TERM OFF ECHO ON FEED OFF VER OFF HEA ON LIN 2000 PAGES 100 ...
    99+
    2024-04-02
  • Oracle固定SQL的执行计划(二)---SPM
    之前写了一篇博客介绍的是用SQL Profile来调整、稳定目标SQL的执行计划,即使无法修改目标SQL的SQL文本。但SQL Profile实际上只是一种亡羊补牢、被动的技术手段,应用在那些执行计划已经发...
    99+
    2024-04-02
  • Linux如何执行shell脚本完成任务计划
    小编给大家分享一下Linux如何执行shell脚本完成任务计划,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!导读众所周知,当前linux跑任务计划我们一般借助于crontab任务计划来实现。但这个任务计划默认最小单位为分钟...
    99+
    2023-06-05
  • Oracle固定SQL的执行计划(一)---SQL Profile
    我们都希望对于所有在Oracle数据库中执行的SQL,CBO都能产生出正确的执行计划,但实际情况却并非如此,由于各种各样的原因(比如目标SQL所涉及的对象的统计信息的不准确,或者CBO内部一些成本计算公式的...
    99+
    2024-04-02
  • oracle如何使用outline固定执行计划事例
    这篇文章主要介绍了oracle如何使用outline固定执行计划事例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.查看现在数据库等待事件...
    99+
    2024-04-02
  • 利用set autotrace来查看执行计划
    设置Autotrace的命令。 分别在执行sql前设置set autotrace 的不同参数,得到不同的想观察的效果 用法: SET AUTOT[RACE] {OFF | ON | TRAC...
    99+
    2024-04-02
  • oracle中查看执行计划的常用方法
    本篇内容介绍了“oracle中查看执行计划的常用方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!本文介绍...
    99+
    2024-04-02
  • iOS快捷指令:执行Python脚本(利用iSH Shell)
    文章目录 前言核心逻辑配置iSH安装Python创建Python脚本配置启动文件测试效果 快捷指令 前言 iOS快捷指令所能做的操作极为有限。假如快捷指令能运行Python程序,那么可操作空间就瞬间变大了。iSH是一款...
    99+
    2023-08-30
    python ios 开发语言
  • Oracle执行计划——使用index full scan的几种情况
    常见有三种情况都有用到index full scan. 1. 查询列就是索引列 2. 对索引列进行order by时 3. 对索列进行聚合计算时 通过案例学调优之--...
    99+
    2024-04-02
  • Oracle DBA常用脚本中转换执行shell脚本是怎样的
    今天就跟大家聊聊有关Oracle DBA常用脚本中转换执行shell脚本是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。最近在开始把Oracl...
    99+
    2024-04-02
  • LINUX下如何用CRON实现定时执行脚本
    这篇文章主要为大家展示了“LINUX下如何用CRON实现定时执行脚本”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“LINUX下如何用CRON实现定时执行脚本”这...
    99+
    2024-04-02
  • Linux用户自定义at、cron计划任务执行的方法
    linux系统中有两种计划任务,一种是只会执行一次 at 计划任务,一种是可以周期性地执行的 cron 计划任务 at 一次性计划任务 描述 在指定的时间执行特定命令(单次),也称为延时动作任务。 用法 at 时间...
    99+
    2022-06-04
    Linux at cron 计划任务
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作