gpt4 book ai didi

java - 从java获取plsql过程的值

转载 作者:行者123 更新时间:2023-11-30 08:13:59 25 4
gpt4 key购买 nike

我想从 PLSQL Proceduer 获取参数。

PROCEDURE BALANCE(requestDate in date, uniqueId in number, field1 out varchar2, field2 out varchar2)
AS
BEGIN
field1 := '110';
field2 := '100';
END BALANCE;

这是java代码:

 javax.persistence.Query query = pm.getEntityManager().createNativeQuery(" declare a number(10);" +
" b number(10);" +
" begin BALANCE(:date,:id,a,b); end;");
query.setParameter("date", transaction.getTransactionId().getRequestDate());
query.setParameter("id", transaction.getTransactionId().getId());
query.executeUpdate();

我想在java程序中使用'a'和'b',但我不知道如何获取'a'和'b'?谢谢。

最佳答案

实际上你不需要hibernate而是JDBC。您没有任何用于输出参数的实体。

要调用它们,只需注册 ut 参数并在调用语句后取回它们。

String getDBUSERByUserIdSql = "{call getDBUSERByUserId(?,?,?,?)}";
callableStatement = dbConnection.prepareCall(getDBUSERByUserIdSql);
callableStatement.setInt(1, 10);
callableStatement.registerOutParameter(2, java.sql.Types.VARCHAR);
callableStatement.registerOutParameter(3, java.sql.Types.VARCHAR);
callableStatement.registerOutParameter(4, java.sql.Types.DATE);

// execute getDBUSERByUserId store procedure
callableStatement.executeUpdate();

String userName = callableStatement.getString(2);
String createdBy = callableStatement.getString(3);
Date createdDate = callableStatement.getDate(4);

代码来自the example

关于java - 从java获取plsql过程的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29913898/

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