Ich möchte REFERENCE als ein Argument an Java-Methode übergeben und transformieren, dann möchte ich in Form von MbElement [] zurückgeben.Wie wird MbElement [] von Java an ESQL zurückgegeben?
Bis jetzt habe ich Folgendes versucht.
ich in ESQL den folgenden Code verwenden
CALL retrieveData(CAST(AGE AS INTEGER),OutputRoot.XMLNSC.employees) into RESULT;
Aufruf Java-Methode wie folgt:
create function retrieveData(IN empId INTEGER,INOUT outputXML REFERENCE)
returns integer
language java
external name "com.test.util.Database.retrieve";
Unten ist die Java-Methode:
public static Long retrieve(Long employeeAge,MbElement[] outputRoot)
{
MbElement xmlnsc = outputRoot[0].getFirstElementByPath("XMLNSC");
MbElement employees = xmlnsc.createElementAsFirstChild(MbElement.TYPE_NAME, "employees", null);
MbElement employee =employees.createElementAsLastChild(MbElement.TYPE_NAME, "employee", "");
employee.createElementAsLastChild(MbElement.TYPE_NAME, "emp-id", 1001);
employee.createElementAsLastChild(MbElement.TYPE_NAME, "emp-name", "john");
employee.createElementAsLastChild(MbElement.TYPE_NAME, "emp-age", 30);
employee.createElementAsLastChild(MbElement.TYPE_NAME, "emp-city", "london");
return new Long(0);
}
Während des oben genannten Code zu testen Es wirft SqlRoutine :: clearDownChildEnv Fehler.
So beheben Sie das Problem. Vielen Dank im Voraus ...