乐趣区

关于数据库:Oracle-自动收集任务统计信息SQL-Tuning

— 查看主动收集工作状态

SELECT CLIENT_NAME,STATUS FROM DBA_AUTOTASK_CLIENT;

SELECT CLIENT_NAME, STATUS
  FROM DBA_AUTOTASK_CLIENT
 WHERE CLIENT_NAME = 'auto optimizer stats collection';

— 敞开信息主动收集 auto optimizer stats collection

BEGIN
  DBMS_AUTO_TASK_ADMIN.DISABLE(CLIENT_NAME => 'auto optimizer stats collection',
                               OPERATION   => NULL,
                               WINDOW_NAME => NULL);
END;
/

— 敞开 SQL 优化器 SQL Tuning Advisor(STA)

BEGIN
  DBMS_AUTO_TASK_ADMIN.DISABLE(CLIENT_NAME => 'sql tuning advisor',
                               OPERATION   => NULL,
                               WINDOW_NAME => NULL);
END;
/

— 敞开主动空间诊断 auto space advisor

BEGIN
  DBMS_AUTO_TASK_ADMIN.DISABLE(CLIENT_NAME => 'auto space advisor',
                               OPERATION   => NULL,
                               WINDOW_NAME => NULL);
END;
/

— 启动主动收集工作 auto optimizer stats collection

BEGIN
  DBMS_AUTO_TASK_ADMIN.ENABLE(CLIENT_NAME => 'auto optimizer stats collection',
                              OPERATION   => NULL,
                              WINDOW_NAME => NULL);
END;
/

— 启动 SQL 优化器 SQL Tuning Advisor(STA)

BEGIN
  DBMS_AUTO_TASK_ADMIN.ENABLE(CLIENT_NAME => 'sql tuning advisor',
                              OPERATION   => NULL,
                              WINDOW_NAME => NULL);
END;
/

— 启动主动空间诊断 auto space advisor

BEGIN
  DBMS_AUTO_TASK_ADMIN.ENABLE(CLIENT_NAME => 'auto space advisor',
                              OPERATION   => NULL,
                              WINDOW_NAME => NULL);
END;
/

— 查看主动收集工作所属工夫窗口组蕴含的子工夫窗口

 EXECUTE DBMS_AUTO_TASK_ADMIN.enABLE;

select * from dba_scheduler_wingroup_members where window_group_name='ORA$AT_WGRP_OS';

— 查看收集统计信息明细

SET LINES 350;
COL WINDOW_NAME FOR A20;
COL DURATION FOR A15;
COL REPEAT_INTERVAL FOR A70;
COL NEXT_START_DATE FOR A25;
COL LAST_START_DATE FOR A25;
SELECT W.WINDOW_NAME,
       W.REPEAT_INTERVAL,
       W.DURATION,
       W.NEXT_START_DATE,
       W.LAST_START_DATE,
       W.ENABLED
  FROM DBA_AUTOTASK_WINDOW_CLIENTS C, DBA_SCHEDULER_WINDOWS W
 WHERE C.WINDOW_NAME = W.WINDOW_NAME
   AND C.OPTIMIZER_STATS = 'ENABLED';

COL JOB_NAME FOR A30
COL ACTUAL_START_DATE FOR A40 
COL RUN_DURATION FOR A30 
SET LINES 180 PAGES 100 

— 10G

SELECT OWNER, JOB_NAME, STATUS, ACTUAL_START_DATE, RUN_DURATION
 FROM DBA_SCHEDULER_JOB_RUN_DETAILS WHERE JOB_NAME = 'GATHER_STATS_JOB' ORDER BY 4; 

— 11G

SELECT OWNER, JOB_NAME, STATUS, ACTUAL_START_DATE, RUN_DURATION 
FROM DBA_SCHEDULER_JOB_RUN_DETAILS WHERE JOB_NAME LIKE 'ORA$AT_OS_OPT_S%' ORDER BY 4;

— 敞开周六

BEGIN
DBMS_SCHEDULER.DISABLE(
NAME=>'"SYS"."SATURDAY_WINDOW"',
FORCE=>TRUE);
END;

— 批改早上 4 点收集

BEGIN
DBMS_SCHEDULER.SET_ATTRIBUTE(
NAME=>'"SYS"."SATURDAY_WINDOW"',
ATTRIBUTE=>'REPEAT_INTERVAL',
VALUE=>'freq=daily;byday=SAT;byhour=8;byminute=0; bysecond=0');
END;
/

— 批改窗口启动工夫

EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('MONDAY_WINDOW','repeat_interval','freq=daily;byday=MON;byhour=22;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('TUESDAY_WINDOW','repeat_interval','freq=daily;byday=TUE;byhour=22;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('WEDNESDAY_WINDOW','repeat_interval','freq=daily;byday=WED;byhour=22;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('THURSDAY_WINDOW','repeat_interval','freq=daily;byday=THU;byhour=22;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('FRIDAY_WINDOW','repeat_interval','freq=daily;byday=FRI;byhour=22;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('SATURDAY_WINDOW','repeat_interval','freq=daily;byday=SAT;byhour=6;byminute=0;bysecond=0');
EXEC DBMS_SCHEDULER.SET_ATTRIBUTE('SUNDAY_WINDOW','repeat_interval','freq=daily;byday=SUN;byhour=6;byminute=0;bysecond=0');

— 调整持续时间 周一

BEGIN
DBMS_SCHEDULER.DISABLE(NAME => 'TUESDAY_WINDOW');
DBMS_SCHEDULER.SET_ATTRIBUTE(NAME => 'TUESDAY_WINDOW',
ATTRIBUTE => 'DURATION',
VALUE => NUMTODSINTERVAL(2, 'hour'));
DBMS_SCHEDULER.ENABLE(NAME => 'TUESDAY_WINDOW');
END;
退出移动版