gpt4 book ai didi

java - 使用 hibernate/jdbc 以值/对象列表作为参数从 java 代码调用存储过程

转载 作者:行者123 更新时间:2023-12-01 14:06:40 25 4
gpt4 key购买 nike

有没有办法使用 hibernate/jdbc 通过 java 代码调用在 SQL Server 上创建的存储过程,并将值/对象列表作为参数传递?如果是的话我怎样才能实现它?我知道如何调用存储过程,但到目前为止我已经使用存储过程只传递了几个参数,而不是完整的值列表,因为我打算进行批量更新/插入。如果我做类似以下的事情,这有意义吗?

getTemplate().getSessionFactory().getCurrentSession().createSQLQuery("CALL proc_insert(:list)").setParameterList("list", objList).executeUpdate();

最佳答案

这可能有帮助使用callableStatement

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);

了解更多信息click

关于java - 使用 hibernate/jdbc 以值/对象列表作为参数从 java 代码调用存储过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18846851/

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