spring+mybatis 批量处理

6 篇文章 0 订阅

1.在java逻辑类

   SqlSession batchSqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH, false);// 获取批量方式的sqlsession

  List<MemberCardInfo> records = new ArrayList<MemberCardInfo>();

MemberCardInfo record = new MemberCardInfo();
record.setCardId(idGenerator.getID(RedisConstant.REDIS_KEY_MEMBER_CARD_INFO_ID, 1, 1));
record.setCardNo(item.get("cardNo").toString());
record.setMemberId(Long.valueOf(item.get("memberId").toString()));
record.setEffectDate(nowTime);
record.setEndDate(nowTime);
record.setCreateTime(nowTime);
record.setUpdateTime(nowTime);
record.setCardStatus(MemberCardConstant.CARD_STATUS_NORMAl);
records.add(record);

    //批量新增member card info,其中参数1对应MemberCardInfoListDao.xml里的insertBatch

       batchSqlSession.insert("com.crt.member.dal.customdao.dao.MemberCardInfoListDao.insertBatch", records);

      batchSqlSession.commit();


2.MemberCardInfoListDao.java

public interface MemberCardInfoListDao {
   
    List<MemberCardInfo> queryListPageMemberCardInfobyParam(Map<String,Object> param,RowBounds rb);
     int insertBatch(List<MemberCardInfo> records);
}


3.MemberCardInfoListDao.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.crt.member.dal.customdao.dao.MemberCardInfoListDao">  

     <insert id="insertBatch" parameterType="java.util.List">
    insert into member_card_info ( <include refid="com.crt.member.dal.autodao.mapper.MemberCardInfoMapper.Base_Column_List" /> ) 
    values 
    <foreach collection="list" item="item" index="index" separator="," >
    (#{item.cardId,jdbcType=BIGINT}, #{item.memberId,jdbcType=BIGINT}, #{item.cardInnerId,jdbcType=VARCHAR},
#{item.cardnoecp,jdbcType=VARCHAR}, #{item.cardNo,jdbcType=VARCHAR}, #{item.cardCvn,jdbcType=VARCHAR},
#{item.cardSign,jdbcType=VARCHAR}, #{item.cobrandedNo,jdbcType=VARCHAR}, #{item.issueDate,jdbcType=TIMESTAMP},
#{item.effectDate,jdbcType=TIMESTAMP}, #{item.endDate,jdbcType=TIMESTAMP}, #{item.cardType,jdbcType=VARCHAR},
#{item.mainCardFlag,jdbcType=VARCHAR}, #{item.issueOrgTypeId,jdbcType=CHAR}, #{item.issueOrgId,jdbcType=VARCHAR},
#{item.cardStatus,jdbcType=VARCHAR}, #{item.cardStyle,jdbcType=VARCHAR}, #{item.issueShopId,jdbcType=VARCHAR},
#{item.optionType,jdbcType=VARCHAR}, #{item.createTime,jdbcType=TIMESTAMP}, #{item.createdBy,jdbcType=VARCHAR},
#{item.updateTime,jdbcType=TIMESTAMP}, #{item.updatedBy,jdbcType=VARCHAR}, #{item.isDeleted,jdbcType=INTEGER},
#{item.optCounter,jdbcType=INTEGER})
    </foreach>   
</insert>

</mapper>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值