【发布时间】:2014-02-21 06:33:41
【问题描述】:
我正在使用 Spring JDBCTemplate 连接到 SQL Server。
我有一个需要插入到 SQL Server 表中的对象列表。
我所做的如下:
public void batchInsert(final List<Bean> list) {
final String sql = "insert into temp"
+ "(id, name, amount, location, time, price) "
+ " values (?, ?, ?, ?, ?, ?)";
getJdbcTemplate().batchUpdate(sql, new BatchPreparedStatementSetter() {
@Override
public void setValues(PreparedStatement ps, int i) throws SQLException {
Bean vo = list.get(i);
ps.setString(1, vo.getId());
ps.setString(2, vo.getName());
ps.setDouble(3, vo.getAmount());
ps.setString(4, vo.getLocation());
ps.setString(5, vo.getTime());
ps.setDouble(6, vo.getPrice());
}
@Override
public int getBatchSize() {
return list.size();
}
});
}
但是现在,我想将参数List<Bean> list 传递给一个存储过程,该过程尽可能高效地处理批量插入。
请问如何实现?
【问题讨论】:
-
根据您的 SQL Server 版本,您可能需要查看Table valued parameters
-
没关系,它看起来像 JDBC doesn't support them yet,虽然这将是前进的方向。 This thread 建议解决方法,但不是很清楚,而且我对 Java 的了解不够,恐怕无法提供帮助。
标签: sql sql-server spring stored-procedures jdbc