适用范围 Oracle Database 12.2
问题概述 Oracle 12.2在每日维护窗口执行自动收集统计信息任务失败,报ORA-20001: Statistics Advisor: Invalid task name for the current user
问题原因
自动任务advisory package的异常,不能正常调用任务。与Bug27774706高度相似。
解决方案
应用补丁27774706后重建advisory package。
分析过程
Oracle中预定义的自动化任务
本案例是Automatic Optimizer Statistics Collection任务执行报ORA-20001
1、检查数据库日志
ORA-20001: Statistics Advisor: Invalid task name for the current user ORA-06512: at "SYS.DBMS_STATS", line 47209 ORA-06512: at "SYS.DBMS_STATS_ADVISOR", line 882 ORA-06512: at "SYS.DBMS_STATS_INTERNAL", line 20059 ORA-06512: at "SYS.DBMS_STATS_INTERNAL", line 22201 ORA-06512: at "SYS.DBMS_STATS", line 47199
自动任务执行期间报ORA-20001: Statistics Advisor任务名无效。 2、检查相关任务
SQL>select name, ctime, how_createdfrom sys.wri$_adv_taskswhere owner_name = 'SYS'and name in ('AUTO_STATS_ADVISOR_TASK','INDIVIDUAL_STATS_ADVISOR_TASK');
no rows selected
检查AUTO_STATS_ADVISOR_TASK和INDIVIDUAL_STATS_ADVISOR_TASK 2个任务, 如果没有返回值,应用补丁27774706后重建advisory package.
SQL> col name for a30select name, ctime, how_createdfrom sys.wri$_adv_taskswhere owner_name = 'SYS'and name in ('AUTO_STATS_ADVISOR_TASK','INDIVIDUAL_STATS_ADVISOR_TASK');
NAME CTIME HOW_CREATED
—————————— ——— ——————————
AUTO_STATS_ADVISOR_TASK 26-NOV-25 CMD
INDIVIDUAL_STATS_ADVISOR_TASK 26-NOV-25 CMD
AUTO_STATS_ADVISOR_TASK和INDIVIDUAL_STATS_ADVISOR_TASK 2个任务如果存在删除后再重建。 3、应用补丁 应用补丁27774706 ,补丁应用后会有with error,可以执行以下语句
UPDATE dba_registry_sqlpatchSET status = 'SUCCESS', action_time = SYSTIMESTAMPWHERE patch_id = 27774706 and status='WITH ERRORS' and rownum=1;COMMIT;
4、修复advisory package 4.1 UTO_STATS_ADVISOR_TASK和INDIVIDUAL_STATS_ADVISOR_TASK不存在的情况
$ sqlplus / as sysdbadrop table WRI$_ADV_DEFINITIONS; @?/rdbms/admin/catadvtb.sql; @?/rdbms/admin/utlrp.sql;execute dbms_advisor.setup_repository; EXEC dbms_stats.init_package();
4.2 UTO_STATS_ADVISOR_TASK和INDIVIDUAL_STATS_ADVISOR_TASK存在的情况
SQL> DECLAREv_tname VARCHAR2(32767);BEGINv_tname := 'AUTO_STATS_ADVISOR_TASK';
DBMS_STATS.DROP_ADVISOR_TASK(v_tname);END;
/
PL/SQL procedure successfully completed.
SQL> DECLAREv_tname VARCHAR2(32767);BEGINv_tname := 'INDIVIDUAL_STATS_ADVISOR_TASK';
DBMS_STATS.DROP_ADVISOR_TASK(v_tname);END;
/
PL/SQL procedure successfully completed.
SQL> col name for a30select name, ctime, how_createdfrom sys.wri$_adv_taskswhere owner_name = 'SYS'and name in ('AUTO_STATS_ADVISOR_TASK','INDIVIDUAL_STATS_ADVISOR_TASK');
no rows selected
执行package重建
SQL> EXEC DBMS_STATS.INIT_PACKAGE();
PL/SQL procedure successfully completed.
SQL> commit;Commit complete.
进行验证
SQL> col name for a30select name, ctime, how_createdfrom sys.wri$_adv_taskswhere owner_name = 'SYS'and name in ('AUTO_STATS_ADVISOR_TASK','INDIVIDUAL_STATS_ADVISOR_TASK');
NAME CTIME HOW_CREATED
—————————— ——— ——————————
AUTO_STATS_ADVISOR_TASK 26-NOV-25 CMD
INDIVIDUAL_STATS_ADVISOR_TASK 26-NOV-25 CMD
advisory package重建完成。
-the end-**MyBologs:** https://www.myhfxf.com https://www.xiaofeihuangfu.comCSDN: https://blog.csdn.net/xfhuangfuITPUB: https://blog.itpub.net/28373936/微信公众号:xfhuangfu
