sql - 如何将参数列表传递给存储过程并在 SQL Server 中执行批量插入

标签 sql sql-server spring stored-procedures jdbc

我正在使用 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/

相关文章:

mysql - 如何通过传递另一个列值来检索列值

php - 如何使用 MySQL Query 和 PHP 分配排名

mysql - SQL,按一列与一个不同列进行分组

sql-server - 将 GROUP BY 与 FIRST_VALUE 和 LAST_VALUE 一起使用

sql-server - SQL Server 数据库恢复失败 - 版本冲突

java - 无法识别 Hibernate 符号 @id @column

mysql - 如何在mysql中选择输赢记录

mysql - 使用 DATETIME 列上的 ORDER BY 优化查询

sql-server - SQL Server 自定义计数器存储过程创建欺骗

spring - Spring数据JPA如何决定调用EntityManager.persist(…)或entityManager.merge(…)方法