我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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将执行计划固定了。



免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何利用Oracle变量优化存储过程执行计划

优化存储过程执行计划可以通过使用Oracle变量来减少重复计算和提高查询性能。以下是一些利用Oracle变量优化存储过程执行计划的方法:使用变量存储查询结果:在存储过程中使用变量来存储查询结果,可以避免重复查询数据库,提高查询性能。例如,将
如何利用Oracle变量优化存储过程执行计划
2024-08-24

编程热搜

目录