将Java文件更改为存储过程

时间:2017-11-30 05:58:38

标签: java xml stored-procedures plsql oracle-sqldeveloper

我有一个java文件名 E2BXmlParser ,我正在阅读和操作从数据库中提取的XML数据。

现在我正在尝试使用Oracle SQL Developer在更改此文件之后执行java文件

CREATE AND COMPILE JAVA SOURCE NAMED "E2BXmlParser" AS

--(Rest of Code).

其余代码看起来像这样 -

import oracle.jdbc.*
import oracle.xdb.XMLType;
import oracle.xml.parser.v2.XMLDocument;
import oracle.jdbc.*;
import org.w3c.dom.*;
import org.xml.sax.InputSource;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.transform.*;
import java.sql.Connection;
import java.util.*
import javax.xml.xpath.*;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.io.StringReader;

class Reaction {

}

public class E2BXmlParser {

   //variables

    public E2BXmlParser(int regReportId, int reportId) {
       //connection
    }
    public static void parseXML(int regReportId, int reportId, int isBlinded, int reportFormid,int pi_is_r3_profile,int pi_max_length,String pi_risk_category) throws SQLException, XPathExpressionException, TransformerException {
        //fetching data
    }
    private static Document getDocumentFromString(String xmlContent) throws Exception {

    }

    private String getStringByElementName(String tagName, Element element) {

    }
    private OracleConnection getConnecton() {
       //oracle connection

    }
private Document getXmlDocumentFromDb(int regReportId, int reportId) {
    //fetching and manipulating data
}
private List<Reaction> getReactionIds() {
    //logic 
}
private void findById(Reaction reaction, String id) {

    //xpath for finding nodes

}
private boolean checkNodeExists(Element el, String nodeName) {
    NodeList list = el.getElementsByTagName(nodeName);
    return list.getLength() > 0;
}
private void updateNode(Reaction reaction, Element el) {

  //update xml

}
private void updateXmlInDB(int regReportId, int reportId) throws SQLException {
    //update xml in db
}

private void updateDrugNode() {
    Element rootElement = document.getDocumentElement();
    //logic
}

private void updateDrugEventandDrugRelatedness(int reportFormid) {
    //update xml 

}

private void updateMedicinalActiveSubstance(int regReportId, int isBlinded, int reportFormid,int pi_is_r3_profile,int pi_max_length,String pi_risk_category) {

   //update xml after fetching data and changing in DB
}

private Boolean compareStrings(String strOne, String strTwo) {

    //logic
}

private void updateDosageInformation() {
   //logic
}

private void updateActiveSubstanceName() {

   updating activesubstance using xpath 

}

private void RemoveDuplicateActiveSubstance(NodeList activesubstancenameList, List<String> names) {

// logic
     }
}

现在它要求在代码中使用多个值(反应,节点列表,节点)。

但事实并非如此 当我从命令行执行java文件时,如

loadjava -user  username/password@DBalias -r E2BXmlParser.java

P.S 我必须将我的E2BXmlParser.java文件更改为E2BXmlParser.sql文件,以便我可以从oracle sql developer执行它。

请帮忙。

1 个答案:

答案 0 :(得分:0)

最简单的解决方案是将类的所有逻辑包装到类中的一个静态方法中。接下来,您必须将此方法发布到pl sql。

静态函数的发布将会(或多或少)像这样。

CREATE PROCEDURE parseXML (regReportId NUMBER, reportId NUMBER, isBlinded NUMBER, reportFormid NUMBER, pi_is_r3_profile NUMBER, pi_max_length NUMBER, pi_risk_category varchar2)
AS LANGUAGE JAVA
NAME 'E2BXmlParser.parseXML(int regReportId, int reportId, int isBlinded, int reportFormid,int pi_is_r3_profile,int pi_max_length,java.lang.String pi_risk_category)';

请注意。在plsql中,您必须使用对象示例String的完整路径 - &gt; java.lang.String

当然oracle允许以更面向对象的方式使用java类,但这更复杂。

有关详细信息,请查看本手册。 https://docs.oracle.com/cd/E18283_01/java.112/e10588/toc.htm

第3章(在Oracle数据库中调用Java方法) - 用于基本解决方案 第6章(使用调用规范发布Java类) - (段落编写对象类型调用规范) - 用于发布完整的Java类。