0

我正在重写一个导入和导出 oracle 数据库的应用程序。我使用 imp.exe 和 exp.exe 作为代码中的进程执行。现在我正在尝试使用 impdp 和 expdp 来代替它们。我在https://docs.oracle.com/研究了一些示例,但是以下代码在 DBMS_DATAPUMP.ADD_FILE 处失败。

DECLARE
  h2 NUMBER;
BEGIN    
  h2 := DBMS_DATAPUMP.OPEN('EXPORT','SCHEMA',NULL, 'MYJOB', 'LATEST');
  DBMS_DATAPUMP.ADD_FILE(h2,'test1.dmp','datapump_dir');
  DBMS_DATAPUMP.METADATA_FILTER(h2,'SCHEMA_EXP','IN (''sc900'')');
  DBMS_DATAPUMP.START_JOB(h2);
  dbms_datapump.detach(h2);
END; 

错误输出是

 ORA-39001: invalid argument value
 ORA-06512: at "SYS.DBMS_SYS_ERROR", line 79
 ORA-06512: at "SYS.DBMS_DATAPUMP", line 3507
 ORA-06512: at "SYS.DBMS_DATAPUMP", line 3756

我连接为 'sys' 和 'datapump_dir' 创建语句已成功执行。

我究竟做错了什么?提前致谢!

4

1 回答 1

1

如果有人会感兴趣,我找到了问题的原因。出于某种原因,即使我指定了默认目录,它也不起作用。但是,当我将 null 传递给此参数时,它可以工作。以下代码有效,唯一的缺点是我只能保存到默认目录

DECLARE
  h2 NUMBER;
BEGIN
  h2 := DBMS_DATAPUMP.OPEN('EXPORT', 'SCHEMA');
  DBMS_DATAPUMP.ADD_FILE(h2, 'example0.dmp', null);
  DBMS_DATAPUMP.METADATA_FILTER(h2,'SCHEMA_EXPR', q'{IN ('SC900')}');
  DBMS_DATAPUMP.START_JOB(h2);
  DBMS_DATAPUMP.DETACH(h2);
END;
/
于 2018-01-10T13:57:25.457 回答