gpt4 book ai didi

java - 从 jdbc 执行 PLSQL 后读取 DBMS_Ouptut

转载 作者:行者123 更新时间:2023-11-30 10:16:01 25 4
gpt4 key购买 nike

我需要使用 jdbc 执行 Oralce PL/SQL 语句,但我正在为如何提取数据而苦苦挣扎。

这是我的声明

DECLARE 
l_xmltype XMLTYPE;
l_ctx dbms_xmlgen.ctxhandle;
BEGIN
l_ctx := dbms_xmlgen.newcontext('select * from myTable where rownun < 10;);
dbms_xmlgen.setrowsettag(l_ctx, 'My_DATA');
dbms_xmlgen.setrowtag(l_ctx, 'My_Element');
l_xmltype := dbms_xmlgen.getXmlType(l_ctx) ;
dbms_xmlgen.closeContext(l_ctx);
dbms_output.put_line(l_xmltype.getClobVal);
dbms_output.get_lines(?, l_xmltype);
End;

还有我的代码

CallableStatement cs = connection.prepareCall(plsql);
cs.registerOutParameter(1, Types.ARRAY,"DBMSOUTPUT_LINESARRAY");
cs.execute();

Array array = null;
array = cs.getArray(1);
Stream.of((Object[]) array.getArray())
.forEach(System.out::println);

我得到了错误

java.sql.SQLException: ORA-06550: line 1, column 380: PLS-00306: wrong number or types of arguments in call to 'GET_LINES'

我不是 PL/SQL 或 jdbc 方面的专家,所以我正在努力寻找解决方案。

最佳答案

GET_LINES 的第二个参数是一个数字,而不是 XMLTYPE。将您的调用更改为:

dbms_output.get_lines(?, 50);

我还展示了一个更完整的示例来说明如何执行此操作 in a similar question .请注意,您还必须先添加以下调用,以启用 dbms_output 集合:

dbms_output.enable();

Note that in case you're using jOOQ, you can automatically fetch server output on any statement .

关于java - 从 jdbc 执行 PLSQL 后读取 DBMS_Ouptut,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50173411/

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