我想从 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/