gpt4 book ai didi

java - 我如何通过 JDBC 调用返回 UDO 的 PL/SQL 函数并解释该结果?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:14:53 26 4
gpt4 key购买 nike

假设我的 UDO(用户定义对象)是:

create or replace
TYPE UDO_PERSON AS object (NAME VARCHAR2(100), AGE INTEGER);

我有一个 PL/SQL 函数

create or replace
FUNCTION CREATE_A_PERSON(NAME VARCHAR2)
RETURN UDO_PERSON
AS
AGE INTEGER;
BEGIN

SELECT dbms_random.value(1,100) INTO AGE FROM DUAL;
RETURN NEW UDO_PERSON(NAME, AGE);

END CREATE_A_PERSON;

我测试了以下方法并且它有效,并且有一些方法可以“解析”结果

...

String select = "SELECT CREATE_A_PERSON('my name') FROM DUAL";
Statement stmt=conn.createStatement();
ResultSet rs= stmt.executeQuery(select);
rs.next();

java.sql.Struct jdbcStruct = (java.sql.Struct)rs.getObject(1);

Object[] attrs = jdbcStruct.getAttributes();
for(int i=0;i<attrs.length;i++){
System.out.println("attrs["+i+"] "+attrs[i].toString());
}

...

但我想使用的是 CallableStatement ,例如:

String procedure = "{? = call CREATE_A_PERSON (?)}";
CallableStatement statement = conn.prepareCall(procedure);

statement.registerOutParameter(1, java.sql.Types.STRUCT); // I tested with OTHER, JAVA_OBJECT
statement.setString(2, "Youre name");

ResultSet rs= statement.executeQuery(); // tried also with execute() and then statement.getObject()...still nothing
java.sql.Struct jdbcStruct = (java.sql.Struct)rs.getObject(1);

...

最后一段代码根据我使用的 java.sql.Type 和执行方法的类型抛出不同类型的异常。

有人吗?我搜索了 Oracle 文档,但发现它非常困惑。

最佳答案

所以解决方案是

String procedure = "{? = call CREATE_A_PERSON (?)}";
CallableStatement statement = conn.prepareCall(procedure);
statement.registerOutParameter(1, java.sql.Types.STRUCT, "UDO_PERSON");
statement.setString(2, "YOURE NAME");
statement.execute();
...

旧行:

statement.registerOutParameter(1, java.sql.Types.STRUCT);

换行:

statement.registerOutParameter(1, java.sql.Types.STRUCT, "UDO_PERSON");

从这里您只需“解析”java.sql.Struct 对象。集合也是如此(虽然我只测试了VARRAY_OF_NUM)你需要使用带有三个参数的registerOutParameter,否则你会看到一些异常,比如“ORA-03115:不支持的网络数据类型或表示”。显然,如果您的 PL/SQL 函数返回 VARRAY,请使用 statement.registerOutParameter(1, OracleTypes.ARRAY, "YOURE_VARRAY_TYPE");

关于java - 我如何通过 JDBC 调用返回 UDO 的 PL/SQL 函数并解释该结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8286769/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com