执行备份脚本报错:
ORA-31634: job already exists
ORA-31664: unable to construct unique job name when defaulted
分析
原因:expdp运行时调用job的唯一名不存在
排查:查询dba_datapump_jobs,正常情况下job_name字段只有SYS_IMPORT_SCHEMA_01和SYS_IMPORT_SCHEMA_02两行记录,如果存在多余记录则会造成以上报错
SELECT * FROM dba_datapump_jobs;
解决:删除表中字段state是NOT RUNNING状态的表
不会删除的看这里
生成清除master table的SQL语句为:
select 'drop table ' || owner_name || '.' || job_name || ';' from dba_datapump_jobs where state = 'NOT RUNNING';
执行上面生成的sql后,再次手动执行脚本,正常运行!