时间:2021-07-01 10:21:17 帮助过:14人阅读
不建议在生产环境中开启自动捕获。
除了在SYSTEM级别中更改该参数之外,还可以在SESSION级别中更改。
自动捕获方式原理是 第一次sql语句执行 先查看数据字典看有对应的sqlplan baseline没(用签名查找),没有的话查看一个log(log中有签名,所谓的签名就是将sql语句格式化后的一个标记,可以不分大小写空格之类),没有的话在log中根据sql_text生成一个签 名。第2次执行SQL语句时候 还是先看有对应的sqlplan baselines没,没有的话查看log中有对应的签名没,有的话(此时已经有了),此时才存入sql plan baselines(这个时候存入的执行计划 ,就是你sql语句此时此刻的执行计划,根据统计信息之类算出来的)。所以这个方式为一个sql语句生成sqlplan baseline需要执行2次sql。
如以下示例:
Session 1:
SQL> select sql_handle,SQL_TEXT,ENABLED,ACCEPTED,FIXED from dba_sql_plan_baselines; no rows selected
此时会话1中,无基线存在。
Session 2:
SQL> alter session set OPTIMIZER_CAPTURE_SQL_PLAN_BASELINES=TRUE; Session altered. SQL> select * from emp where empno=7369; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- --------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-DEC-80 800 20
会话2中打开自动捕获,并第一次执行我们的语句。
Session 1:
SQL> select sql_handle,SQL_TEXT,ENABLED,ACCEPTED,FIXED from dba_sql_plan_baselines; no rows selected
此时会话1中,仍无基线存在。
Session 2:
SQL> select * from emp where empno=7369; EMPNO ENAME JOB MGR HIREDATE SAL COMM DEPTNO ---------- ---------- --------- ---------- --------- ---------- ---------- ---------- 7369 SMITH CLERK 7902 17-DEC-80 800 20
会话2中,再次执行语句。
Session 1:
SQL> select sql_handle,SQL_TEXT,ENABLED,ACCEPTED,FIXED from dba_sql_plan_baselines; SQL_HANDLE SQL_TEXT ENA ACC FIX ------------------------------ ---------------------------------------- --- --- --- SQL_353e8c17a551f70c select * from emp where empno=7369 YES YES NO
此时,该会话中可以发现已经捕获了我们执行的SQL语句。
手工加载即可以配合自动捕获使用,也可以作为独立的手段使用。加载操作我们用DBMS_SPM包进行操作,既可以从SQL TUNING SETS中加载也可以从Cursor Cache中加载特定的语句。手工加载的被默认标记为可接受的(accepted=yes)。如果该语句已经在基线中存在,则该计划将被添加到执行计划中,否则将新建。
下面的代码演示了使用LOAD_PLANS_FROM_SQLSET函数加载在STS中的SQL语句。加载的过程中可以指定过滤条件。
SET serveroutput ON DECLARE my_int pls_integer; BEGIN my_int := dbms_spm.load_plans_from_sqlset ( sqlset_name => ‘b8rc6j0krxwdc_sqlset_test‘, basic_filter => ‘sql_id="b8rc6j0krxwdc"‘, sqlset_owner => ‘SYS‘, fixed => ‘NO‘, enabled => ‘YES‘); DBMS_OUTPUT.PUT_line(my_int); END; /
函数LOAD_PLANS_FROM_CURSOR_CACHE则允许从Cursor Cache进行加载。该函数存在4个重载,可以通过多个条件进行定位,比如SQL_ID,SQL_TEXT,PARSING_SCHEMA_NAME,MODULE和ACTION等。
下面的代码示例演示如何加载:
DECLARE l_plans_loaded PLS_INTEGER; BEGIN l_plans_loaded := DBMS_SPM.load_plans_from_cursor_cache( sql_id => ‘12mf9db6pxnmd‘,PLAN_HASH_VALUE => ‘1608914532‘); END; /
上述代码中演示为指定的SQL_ID和指定的执行计划进行加载。也可以不指定执行计划,那将加载该语句所有的执行计划。
可以注意到的是LOAD_PLANS_FROM_SQLSET和LOAD_PLANS_FROM_CURSOR_CACHE都有一个返回值,该返回值的意思为共加载了多少个执行计划。
视图DBA_SQL_PLAN_BASELINES只存了计划基线的一般信息,而完整的执行计划信息查看则需要通过DBMS_XPLAN包进行查询。
函数DISPLAY_SQL_PLAN_BASELINE将返回格式化好的信息,可以指定一个或者全部的执行计划,共存在3种格式化模式:BASIC、TYPICAL和ALL。
下面演示了之前自动捕获的基线中的执行计划:
SET LONG 10000
SQL> select sql_handle,PLAN_NAME,ENABLED,ACCEPTED,FIXED from dba_sql_plan_baselines;
SQL_HANDLE PLAN_NAME ENA ACC FIX
------------------------------ ------------------------------ --- --- ---
SQL_353e8c17a551f70c SQL_PLAN_3agnc2ykp3xsc695cc014 YES YES NO
SQL> SELECT * FROM TABLE(DBMS_XPLAN.display_sql_plan_baseline(SQL_HANDLE => ‘SQL_353e8c17a551f70c‘, plan_name=>‘SQL_PLAN_3agnc2ykp3xsc695cc014‘, FORMAT => ‘ALL‘));
--------------------------------------------------------------------------------
SQL handle: SQL_353e8c17a551f70c
SQL text: select * from emp where empno=7369
--------------------------------------------------------------------------------
--------------------------------------------------------------------------------
Plan name: SQL_PLAN_3agnc2ykp3xsc695cc014 Plan id: 1767686164
Enabled: YES Fixed: NO Accepted: YES Origin: AUTO-CAPTURE
--------------------------------------------------------------------------------
Plan hash value: 2949544139
--------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
--------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 38 | 1 (0)| 00:00:01 |
| 1 | TABLE ACCESS BY INDEX ROWID| EMP | 1 | 38 | 1 (0)| 00:00:01 |
|* 2 | INDEX UNIQUE SCAN | PK_EMP | 1 | | 0 (0)| 00:00:01 |
--------------------------------------------------------------------------------------
Query Block Name / Object Alias (identified by operation id):
-------------------------------------------------------------
1 - SEL$1 / EMP@SEL$1
2 - SEL$1 / EMP@SEL$1
Predicate Information (identified by operation id):
---------------------------------------------------
2 - access("EMPNO"=7369)
Column Projection Information (identified by operation id):
-----------------------------------------------------------
1 - "EMPNO"[NUMBER,22], "EMP"."ENAME"[VARCHAR2,10],
"EMP"."JOB"[VARCHAR2,9], "EMP"."MGR"[NUMBER,22], "EMP"."HIREDATE"[DATE,7],
"EMP"."SAL"[NUMBER,22], "EMP"."COMM"[NUMBER,22], "EMP"."DEPTNO"[NUMBER,22]
2 - "EMP".ROWID[ROWID,10], "EMPNO"[NUMBER,22]
ALTER_SQL_PLAN_BASELINE函数提供了更改基线内执行计划的属性的方法。
属性有如下几个:
如下演示了如何将一个执行计划的属性fixed标记为YES。
SQL> select SQL_HANDLE,PLAN_NAME,DESCRIPTION,ENABLED,ACCEPTED,FIXED,AUTOPURGE from dba_sql_plan_baselines; SQL_HANDLE PLAN_NAME DESCRIPTION ENA ACC FIX AUT ------------------------------ ------------------------------ ------------------------------ --- --- --- --- SQL_353e8c17a551f70c SQL_PLAN_3agnc2ykp3xsc695cc014 YES YES NO YES SQL> SQL> SET SERVEROUTPUT ON SQL> DECLARE 2 l_plans_altered PLS_INTEGER; 3 BEGIN 4 l_plans_altered := DBMS_SPM.alter_sql_plan_baseline( 5 sql_handle => ‘SQL_353e8c17a551f70c‘, 6 plan_name => ‘SQL_PLAN_3agnc2ykp3xsc695cc014‘, 7 attribute_name => ‘fixed‘, 8 attribute_value => ‘YES‘); 9 10 DBMS_OUTPUT.put_line(‘Plans Altered: ‘ || l_plans_altered); 11 END; 12 / Plans Altered: 1 PL/SQL procedure successfully completed. SQL> select SQL_HANDLE,PLAN_NAME,DESCRIPTION,ENABLED,ACCEPTED,FIXED,AUTOPURGE from dba_sql_plan_baselines; SQL_HANDLE PLAN_NAME DESCRIPTION ENA ACC FIX AUT ------------------------------ ------------------------------ ------------------------------ --- --- --- --- SQL_353e8c17a551f70c SQL_PLAN_3agnc2ykp3xsc695cc014 YES YES YES YES
SPM的库存放于SYSAUX表空间,存储了SQL PLAN BASELINES,以及语句LOG、计划历史和SQL PROFILE。其空间的使用有两个键值对属性控制,可以通过DBMS_SPM.CONFIGURE进行配置管理。
参数如下:
其配置可以通过视图DBA_SQL_MANAGEMENT_CONFIG进行查询。
下面的代码演示如何更改配置参数:
SQL> select * from dba_sql_management_config; PARAMETER_NAME PARAMETER_VALUE LAST_MODIFIED MODIFIED_BY ------------------------------ --------------- ------------------------------ ------------------------------ SPACE_BUDGET_PERCENT 10 PLAN_RETENTION_WEEKS 53 SQL> show user USER is "SYS" SQL> BEGIN 2 DBMS_SPM.configure(‘space_budget_percent‘, 11); 3 DBMS_SPM.configure(‘plan_retention_weeks‘, 54); 4 END; 5 / PL/SQL procedure successfully completed. SQL> select * from dba_sql_management_config; PARAMETER_NAME PARAMETER_VALUE LAST_MODIFIED MODIFIED_BY ------------------------------ --------------- ------------------------------ ------------------------------ SPACE_BUDGET_PERCENT 11 2017-04-08 16:50:12 SYS PLAN_RETENTION_WEEKS 54 2017-04-08 16:50:12 SYS
DROP_SQL_PLAN_BASELINE函数可以删除一个或者多个执行计划,如果未指定plan name的时候,将删除所有的对应执行计划。
示例如下:
SQL> select SQL_HANDLE,PLAN_NAME,DESCRIPTION,ENABLED,ACCEPTED,FIXED,AUTOPURGE from dba_sql_plan_baselines; SQL_HANDLE PLAN_NAME DESCRIPTION ENA ACC FIX AUT ------------------------------ ------------------------------ ------------------------------ --- --- --- --- SQL_353e8c17a551f70c SYK SPM DEMO YES YES YES YES SQL> SET SERVEROUTPUT ON SQL> DECLARE 2 l_plans_dropped PLS_INTEGER; 3 BEGIN 4 l_plans_dropped := DBMS_SPM.drop_sql_plan_baseline ( 5 sql_handle => ‘SQL_353e8c17a551f70c‘, 6 plan_name => ‘SYK SPM DEMO‘); 7 8 DBMS_OUTPUT.put_line(l_plans_dropped); 9 END; 10 / 1 PL/SQL procedure successfully completed. SQL> select SQL_HANDLE,PLAN_NAME,DESCRIPTION,ENABLED,ACCEPTED,FIXED,AUTOPURGE from dba_sql_plan_baselines; no rows selected
Bullet:ORACLE Using SQL Plan Management(一)
标签:管理 高效 多少 operation manage emd class procedure .config