java - 使用 ODI SDK 在 Odi 12c 中导入对象

标签 java oracle groovy oracle-data-integrator

我正在尝试使用 Groovy 脚本和 ODI SDK 在 ODI 12c 中自动导入映射 (XML)。但我的代码一直运行,没有任何结果。这是我的代码。

txnDef = new DefaultTransactionDefinition()
tm = odiInstance.getTransactionManager()
tme = odiInstance.getTransactionalEntityManager()
txnStatus = tm.getTransaction(txnDef)
ImportServiceImpl importSrv = new ImportServiceImpl(odiInstance);
importSrv.importObjectFromXml(importSrv.IMPORT_MODE_SYNONYM_INSERT, filename, parentObj, true, null, true);
tm.commit(txnStatus)

该代码会无限期运行,直到我手动终止该程序。我不明白有什么问题。 链接到javadoc:https://docs.oracle.com/middleware/1213/odi/reference-java-api/oracle/odi/impexp/IImportService.html#importObjectFromXml(int,%20java.lang.String,%20boolean,%20char[],%20boolean)

而且,我不明白该方法中的第四个参数

void importObjectFromXml(int pImportMode,
                   java.lang.String pFileName,
                   IImportRoot pObjectParent,
                   boolean pDeclareMissingRepository,
                   char[] pExportKey,
                   boolean pImportWithoutCipherData)
                     throws OdiImportNotSupportedException,
                            OdiImportException,
                            java.io.IOException

我尝试对 pDeclareMissingRepository 使用 true 和 false,但没有任何效果。如果我遗漏了什么,请帮忙。

谢谢。

最佳答案

您应该使用importObjectFromXml而不是importFromXml这是特定于 SmartImport .

尝试使用 importSrv.importObjectFromXml(IImportService.IMPORT_MODE_SYNONYM_INSERT, filename, parentObj, true, null, true)

pDeclareMissingRepository 与 11g 中对象的识别方式相关联,具有内部 ID 和存储库 ID。导入时,它会检查是否可以识别导出对象的存储库 ID。我认为它不再被使用,但为了您的使用,您可以安全地将值保留为 true。

关于java - 使用 ODI SDK 在 Odi 12c 中导入对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41225923/

相关文章:

java - 即使在重新排列列表后,如何在自定义 ListView 中获得正确的位置项?

sql - Oracle SQL 语句 select u'' from dual

java - Groovy 脚本运行 java 主类

java - Maven 项目找不到 Groovy 类

java - 如何控制连接到 RMI 服务器的多个客户端线程

java - 是否可以为现有的 Scanner 对象指定新的源?

java - 如何在 String readAllBytes 中保留换行符

c - 甲骨文11g : osutil package; no PATH on CentOS 7?

c# - 如何在 Oracle PL/SQL 中传递逗号分隔的字符串并遍历它以执行查询?

regex - 使用正则表达式解析 ssh-config 文件