spring+mybatis一个方法执行多条更新语句,实现批量DML

在实际开发中,经常会遇到一个方法里需要更新多张表的情况,在使用spring+mybatis的时候,我们一般写多个dao方法分别与mapper中<update>或<insert>标签对应,然后在service中调用这么多个dao方法,这样不仅浪费人力物力,代码也不好看,全是updateXx1/updateXx2/insertXx3/insertXx4等。

笔者经过查看mybatis的源码,发现mybatis确实不支持一个<update>中写多条语句,这是因为mybatis底层其实是使用PreparedStatement实现的,这个东西在初始化的时候就得传一个sql语句进去,然后对于?参数再使用setXxx()填充进去,mybatis为了偷懒就没有实现多条语句的操作。

笔者经过慎重思考及实验,得出以下三种实现方法:

  1. 使用Statement,把sql语句写在代码里,通过其addBatch(sql)方法(此方法无法在PreparedStatement中使用)把sql语句加进去,然后批量执行,但是这种方法有个问题,你得先把参数写死在sql中,这当然是不建议的啦,sql注入,你懂的~~
  2. 使用存储过程,这当然是最简单的方法啦,但是,你得先能干得过DBA,再说了,你不能每次两次以上的更新都去麻烦DBA,不是么~~
  3. 自己通过mybatis的API改造出来一个可以多次更新的方法,以下介绍的方法就使用这种方法_

笔者把mybatis的API翻了个底朝天,终于写出了以下方法,直接上代码:
(以下代码,为节约空间,把package和import都干掉了)

/**
 * VO 公共数据库操作dao
 * 
 * @version 1.0
 */
public class BaseSqlDaoImpl<T> implements BaseSqlDao<T> {
   
  private static Logger logger = LoggerFactory.getLogger(BaseSqlDaoImpl.class);
 
  /**
   * Mapper包路径
   */
  private String baseMapperPackage;

  public String getBaseMapperPackage() {
   
    return baseMapperPackage;
  }

  public void setBaseMapperPackage( String baseMapperPackage ) {
   
    this.baseMapperPackage = baseMapperPackage;
  }

  @Resource
  private SqlSessionFactory sqlSessionFactory;

  /**
   * Alan添加,用于一个mapper更新多个表
   * 注:
   * (1)Connection不用close,mybatis自己会回收;
   * (2)使用此方法可以使用spring的事务管理
   * 
   * @param params
   * @return
   * @throws DaoException
   */
  @Override
  public void updateMultiTables( Map<String, Object> params ) throws Exception {
   
    SqlSession sqlSession = sqlSessionFactory.openSession();
    PreparedStatement ps = null;
    try {
   
      String selectVoName =
          params.get("selectVoName") == null ? "baseSelectListByVo" : params.get("selectVoName").toString();
          
      //此处getBaseMapperPackage()如果取不到值,可以直接写*Mapper.java类所在的包名
      String mapperName = getBaseMapperPackage() + "." + params.get("mapperClassType");

      Connection connection = sqlSession.getConnection();

      BoundSql boundSql =
          sqlSession.getConfiguration().getMappedStatement(mapperName + "." + selectVoName).getBoundSql(params);

      String[] sqls = boundSql.getSql().split(";");
      List<
  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值