给小白的oracle优化工具,了解一下

有时懒得分析或语句太长,可以尝试用oracle的dbms_sqldiag包进行sql优化,


--How To Use DBMS_SQLDIAG To Diagnose Query Performance Issues (Doc ID 1386802.1)
--诊断SQL 性能
SET ECHO ON
SET LINESIZE 132
SET PAGESIZE 999
SET LONG 999999
SET SERVEROUTPUT ON

DECLARE
 v_sql_diag_task_id varchar2(100);
BEGIN
v_sql_diag_task_id := DBMS_SQLDIAG.CREATE_DIAGNOSIS_TASK (
 sql_id=>'&sql_id',
 problem_type => DBMS_SQLDIAG.PROBLEM_TYPE_PERFORMANCE,
 time_limit => 900,
 task_name => 'PROBLEM_TYPE_PERFORMANCE_task' );

DBMS_SQLTUNE.SET_TUNING_TASK_PARAMETER(v_sql_diag_task_id,'_SQLDIAG_FINDING_MODE',DBMS_SQLDIAG.SQLDIAG_FINDINGS_FILTER_PLANS);
END;
/

--观察 Check the Task Created
col owner for a12
col task_name for a35
col advisor_name for a25
SELECT DISTINCT owner, task_name, advisor_name,status FROM DBA_ADVISOR_TASKS WHERE advisor_name ='SQL Repair Advisor' AND task_name like '%PERF%' ORDER BY 1;

--执行任务
BEGIN
 DBMS_SQLDIAG.EXECUTE_DIAGNOSIS_TASK (
        task_name => 'PROBLEM_TYPE_PERFORMANCE_task' );
END;
/

--看结果
SET LONG 9999999
SET PAGESIZE 500
SELECT DBMS_SQLDIAG.REPORT_DIAGNOSIS_TASK ('PROBLEM_TYPE_PERFORMANCE_task' ) as recommendations FROM DUAL;

--如果觉得还行 接受结果
BEGIN
 DBMS_SQLDIAG.ACCEPT_SQL_PATCH(
   task_name =>'PROBLEM_TYPE_PERFORMANCE_task',
   task_owner => 'M_LINCS',
   replace => TRUE);
END;
/

--确认生效
SELECT name, status FROM dba_sql_patches WHERE name LIKE '%SYS%';

--打扫房屋 清理任务
BEGIN
 DBMS_SQLDIAG.DROP_DIAGNOSIS_TASK (
     task_name => 'PROBLEM_TYPE_PERFORMANCE_task' );
END;
/

--确认清理完毕
SELECT DISTINCT owner, task_name, advisor_name FROM DBA_ADVISOR_TASKS WHERE advisor_name ='SQL Repair Advisor'
AND task_name like '%PERF%' ORDER BY 1;

--后悔了 删除优化措施(sql补丁)
SELECT name, status FROM dba_sql_patches WHERE name LIKE '%SYS%';

---Drop the SQL Patch.
---Replace following patch name with actual name of the SQL Patch
--- from previous query output.
BEGIN
  DBMS_SQLDIAG.DROP_SQL_PATCH (
      name=> 'SYS_SQLPTCH_<string>');
END;
/

--确认删除优化措施
--- Verify that the SQL Patch has been dropped.
---
SELECT name, status FROM dba_sql_patches WHERE name LIKE '%SYS%';


有时可能没有建议
在这里插入图片描述
此路不同,再想他法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值