Spring 使用 JdbcTemplate 批量操作

 1、新建一个Setter类并继承 BatchPreparedStatementSetter
package  com.allyroot.bjmvemis.webapp.util.setter;

import  java.sql.PreparedStatement;
import  java.sql.SQLException;
import  java.util.List;

import  org.springframework.jdbc.core.BatchPreparedStatementSetter;

import  com.allyroot.bjmvemis.model.SysFunc;

public   class  RoleFuncSetter  implements  BatchPreparedStatementSetter {

        private  Long  roleId  ;
        private  List<SysFunc>  sysFuncs  ;
      
        public  RoleFuncSetter(Long roleId, List<SysFunc> sysFuncs){
              this  . roleId  = roleId;
              this  . sysFuncs  = sysFuncs;
      }
      
        @Override
        public   int  getBatchSize() {
              return   sysFuncs  .size();
      }

        @Override
        public   void  setValues(PreparedStatement ps,  int  i)  throws  SQLException {
            SysFunc sysFunc =  sysFuncs  .get(i);
              if  (sysFunc!=  null ){
                  ps.setLong(0,  roleId  );
                  ps.setLong(1, sysFunc.getFuncId());
            }
      }

}

2、在调用的impl 类中 需要继承 spring 的 JdbcDaoSupport,然后使用  batchUpdate() 方法进行批量操作
String sql =  "insert into role_func(role_id,func_id) values (?,?)"  ;
getJdbcTemplate().batchUpdate(sql,  new  RoleFuncSetter(roleId, sysFuncs));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值