Oracle 12c自动统计信息任务报错ORA-20001

来源:这里教程网 时间:2026-03-03 23:07:38 作者:

适用范围 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中预定义的自动化任务 image.png 本案例是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

相关推荐