我正在使用 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
到一个尽可能高效地处理批量插入的存储过程。请问这个怎么实现?
最佳答案
首先,不要直接编写查询,因为它可能会破坏您的应用程序的安全性。对于批量数据存储,通常遵循的方式是 XML 方式。尝试通过 XML 实现它。
关于sql - 如何将参数列表传递给存储过程并在 SQL Server 中执行批量插入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21927001/