mybatisPlus指定字段批量执行

saveOrUpdateBatchByColumn(memberCompanyByBrainList, item -> new LambdaQueryWrapper<MmsMemberCompany>()
                        .eq(MmsMemberCompany::getUnifiedSocialCreditCode, item.getUnifiedSocialCreditCode())
                        .eq(MmsMemberCompany::getSite, item.getSite())
                );
public  boolean saveOrUpdateBatchByColumn(Collection<MmsMemberCompany> entityList, Function<MmsMemberCompany, LambdaQueryWrapper> function) {
        return this.saveOrUpdateBatch(this.entityClass, this.mapperClass, LogFactory.getLog(getClass()), entityList, 100, (sqlSession, entity) -> {
            Map<String, Object> param = Maps.newHashMap();
            param.put(com.baomidou.mybatisplus.core.toolkit.Constants.ENTITY, entity);
            param.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, function.apply(entity));
            return CollectionUtils.isEmpty(sqlSession.selectList(this.getSqlStatement(SqlMethod.SELECT_MAPS), param));
        }, (sqlSession, entity) -> {
            Map<String, Object> param = Maps.newHashMap();
            param.put(com.baomidou.mybatisplus.core.toolkit.Constants.ENTITY, entity);
            param.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, function.apply(entity));
            sqlSession.update(this.getSqlStatement(SqlMethod.UPDATE), param);
        });
    }

    public static <E> boolean saveOrUpdateBatch(Class<?> entityClass, Class<?> mapper, Log log, Collection<MmsMemberCompany> list, int batchSize, BiPredicate<SqlSession,MmsMemberCompany> predicate, BiConsumer<SqlSession, MmsMemberCompany> consumer) {
        String sqlStatement = SqlHelper.getSqlStatement(mapper, SqlMethod.INSERT_ONE);
        return SqlHelper.executeBatch(entityClass, log, list, batchSize, (sqlSession, entity) -> {
            if (predicate.test(sqlSession, entity)) {
                sqlSession.insert(sqlStatement, entity);
            } else {
                consumer.accept(sqlSession, entity);
            }
        });
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值