Spring JdbcTemplate 批量插入或更新操作

用 JdbcTemplate 进行批量插入或更新操作

方法一:

代码只是测试用的一个小例子。

public int insertContractAch(List list) throws DataAccessException {
final List temList = list;
String sql = "insert into contract_ach_t " +
" values(?,to_date(?,'yyyy-mm-dd'),?,?) ";
try{
int[] ii = this.getJdbcTemplate().batchUpdate(sql, new MyBatchPreparedStatementSetter(temList));
return ii.length;
}catch (org.springframework.dao.DataAccessException e) {
e.printStackTrace();
throw new DataAccessException(e.getMessage());
}
}
/**
* 处理批量插入的回调类
* */
private class MyBatchPreparedStatementSetter implements BatchPreparedStatementSetter{
final List temList;
/**通过构造函数把要插入的数据传递进来处理*/
public MyBatchPreparedStatementSetter(List list){
temList = list;
}
public int getBatchSize() {
return temList.size();
}

public void setValues(PreparedStatement ps, int i)
throws SQLException {
ContractAchVO contractAchVO = (ContractAchVO)temList.get(i);
ps.setString(1, contractAchVO.getContractCode());
ps.setString(2, contractAchVO.getCreateDate());
ps.setString(3, contractAchVO.getEmployeeId());
ps.setString(4, contractAchVO.getPercent());
}
}

方法二:

//插入很多书(批量插入用法)
public void insertBooks(List<Book> book)
{
final List<Book> tempBook=book;
String sql="insert into book(name,pbYear) values(?,?)";
jdbcTemplate.batchUpdate(sql, new BatchPreparedStatementSetter()
{
public void setValues(PreparedStatement ps,int i)throws SQLException
{
String name=tempBook.get(i).getName();
int pbYear=tempBook.get(i).getPbYear();
ps.setString(1, name);
ps.setInt(2, pbYear);
}
public int getBatchSize()
{
return tempBook.size();
}
});

}


更多相关文章

  1. 如何删除android中的蓝色操作栏?
  2. SQL Server 执行计划操作符详解(1)——断言(Assert)
  3. Android之仿B612咔叽滤镜列表操作
  4. 向Android操作栏中添加操作项和浮动菜单项
  5. Android学习之Asynctask异步操作
  6. Java操作数据库之jdbc【原生方式】
  7. Android复习练习十二(自定义ContentProvider实现其他应用操作本
  8. 显示操作栏和向上导航 - Android
  9. Android中的内存储、外存储概念、文件操作与PC端的有些不同

随机推荐

  1. android子线程中刷新界面控件
  2. Android 控件的显示和隐藏
  3. Android WebView中的JavaScript调用andro
  4. 切换选项卡
  5. Android 轮询实现的三种方式
  6. android开源工程
  7. Android系统属性SystemProperties.set/ge
  8. 编译V8静态库 for Android
  9. Android Ble
  10. adb connect 失败时(unable to connect t