我有一个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执行它。
请帮忙。
答案 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类。