从plsql调用java时Oracle如何导入缺少的java类

Posted

技术标签:

【中文标题】从plsql调用java时Oracle如何导入缺少的java类【英文标题】:Oracle how to import missing java classes when calling java from plsql 【发布时间】:2017-10-05 08:22:51 【问题描述】:

我正在尝试逐步编写一个 java 函数,该函数可以采用 Oracle XML (BI) Publisher Report(不是商业智能中使用的 BI Publisher,而是 Oracle Applications 使用的 XML Publisher)功能,并将报告的输出提供为一块。所以基本上我想采用一个报告定义和模板来输出税务文件,而不是将税务文件返回到一个 clob 中,然后我可以使用 PLSQL 进一步操作。如果有人知道可以执行此操作的现有功能,请告诉我。

我对 Java 不太了解,我接受了这个 Stack Overflow Calling Java from PL/SQL 问题并尝试开始并扩展它。

但是我无法将某些类导入 Java 程序。

CREATE OR REPLACE AND COMPILE JAVA SOURCE NAMED "Hello" AS
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.Serializable;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import oracle.apps.xdo.oa.schema.server.TemplateHelper;
public class Hello

   public static String world()
   
      return "Hello world";
   
;
/

如果我尝试import oracle.apps.xdo.oa.schema.server.TemplateHelper;,Java 编译会失败并显示

JAVA SOURCE 的错误你好:

LINE/COL ERROR
-------- -----------------------------------------------------------------
0/0      Hello:13: cannot find symbol
0/0      symbol  : class TemplateHelper
0/0      1 error
0/0      import oracle.apps.xdo.oa.schema.server.TemplateHelper;
0/0      ^
0/0      location: package oracle.apps.xdo.oa.schema.server

类 TemplateHelper 位于服务器上的 $JAVA_TOP/oracle/apps/xdo/oa/schema/server/TemplateHelper.class 下,其中 $JAVA_TOP 包含在 CLASSPATH 中。

我也试过

loadjava -user apps ./oracle/apps/xdo/oa/schema/server/TemplateHelper.class

但由于某种原因,这会返回

SQL Error while connecting with oci8 driver to default database: Closed Connection
exiting  : could not open connection

即使所有其他程序都可以正常连接。

有谁知道如何导入课程?

【问题讨论】:

您可以尝试在类路径中包含 $JAVA_TOP/oracle/apps/xdo/oa/schema/server。你在使用任何 IDE 吗? @Aura 这不使用CLASSPATH 或任何IDE - 这是将类加载到Oracle 数据库中,以便可以在内部引用它们。 loadjava 应用程序是执行此操作的正确方法,因此问题归结为尝试找出 loadjava 失败的原因并进行修复。 @Aura 尝试了 CLASSPATH=$CLASSPATH:/oracle/hcmgrpd1/fs2/EBSapps/comn/java/classes/oracle/apps/xdo/oa/schema/server,然后使用 SQL Plus 再次运行。没用 您引用的class 文件几乎肯定会依赖于同一包中的其他类,因此在您浏览时通过class 加载它class 将是一个非常痛苦的经历多重依赖。相反,只需使用loadjava 加载包含整个包的jar @Superdooperhero Oracle 不使用CLASSPATH 系统,它有自己的内部CLASSPATH(我相信它指的是单个目录,不能修改)。使用loadjava 应用程序或CREATE JAVA CLASS 是向CLASSPATH 添加类的方法。 【参考方案1】:

你可以试试CREATE JAVA CLASS:

CREATE OR REPLACE DIRECTORY xml_template_dir
  AS '/path/to/oracle/apps/xdo/oa/schema/server/';
/

CREATE JAVA CLASS USING BFILE (xml_template_dir, 'TemplateHelper.class' )
/

然而,虽然这可能会加载该类,但它几乎肯定会有其他依赖项,并且在您尝试使用该类时会失败,然后您将需要加载这些依赖项,然后是依赖项依赖项等等......

你最好找到一个包含整个包的JAR(或者从你现有的目录结构中自己创建包)并使用loadjava

loadjava -user APPS/password@sid -resolve XML_Publisher.jar

(如果您需要覆盖无法加载的现有类,那么您可能还需要-force 选项。)

然后您可以使用以下方法测试是否有任何内容加载失败:

SELECT object_name
FROM   user_objects
WHERE  object_type = 'JAVA CLASS'
AND    status != 'VALID';

还要注意,仅仅因为类加载成功并不意味着调用该类时不会产生运行时异常。

【讨论】:

以上是关于从plsql调用java时Oracle如何导入缺少的java类的主要内容,如果未能解决你的问题,请参考以下文章

从 plsql 调用 java 类文件时无法将 int 值分配给 A JAVA.OBJECT

从 Spring JAVA 中的 oracle PLSQL 函数获取结果集时出错

如何用plsql从oracle中导入导出数据

ORACLE中用PLSQL如何把.DMP文件导入到库中?

ORACLE中用PLSQL如何把.DMP文件导入到库中?

plsql导入dmp文件存储过程需要删吗