有没有办法使用 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/