mybatis-plus saveOrUpdateBatchByUniquekey 插入或更新按自定义唯一索引

mybatis-plus 自带的saveOrUpdateBatch 是以主键来判断插入 或更新的, 如何根据唯一索引实现呢?

## mysql 定义唯一索引 unique key: (salary_date, tenant_id, type, id_no)

@Transactional(rollbackFor = Exception.class)
@Override
public boolean saveOrUpdateBatchByUniqueKey(List<Salary> list) {
    // 这里主要是查询唯一约束对应的记录是否存在
    return SqlHelper.saveOrUpdateBatch(entityClass, this.mapperClass, super.log, list, DEFAULT_BATCH_SIZE, (sqlSession, entity) -> {
        LambdaQueryWrapper<Salary> queryWrapper = Wrappers.<Salary>lambdaQuery()
                .eq(Salary::getSalaryDate, entity.getSalaryDate())
                .eq(Salary::getTenantId, entity.getTenantId())
                .eq(Salary::getType, entity.getType())
                .eq(Salary::getIdNo, entity.getIdNo());

        Map<String, Object> queryParam = CollectionUtils.newHashMapWithExpectedSize(1);
        queryParam.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, queryWrapper);
        return CollectionUtils.isEmpty(sqlSession.selectList(getSqlStatement(SqlMethod.SELECT_LIST), queryParam));
    }, (sqlSession, entity) -> {
        LambdaUpdateWrapper<Salary> updateWrapper = new LambdaUpdateWrapper<>();
        updateWrapper.eq(Salary::getSalaryDate, entity.getSalaryDate())
                .eq(Salary::getTenantId, entity.getTenantId())
                .eq(Salary::getType, entity.getType())
                .eq(Salary::getIdNo, entity.getIdNo());
        Map<String, Object> param = CollectionUtils.newHashMapWithExpectedSize(2);
        param.put(com.baomidou.mybatisplus.core.toolkit.Constants.ENTITY, entity);
        param.put(com.baomidou.mybatisplus.core.toolkit.Constants.WRAPPER, updateWrapper);
        sqlSession.update(getSqlStatement(SqlMethod.UPDATE), param);
    });
}

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Mybatis-Plus提供了批量插入更新的功能,可以大大提高数据操作的效率。 批量插入可以使用Mybatis-Plus提供的insertBatch方法,将多条记录一次性插入到数据库中。示例代码如下: List<User> userList = new ArrayList<>(); // 添加多条记录到userList中 userMapper.insertBatch(userList); 批量更新可以使用Mybatis-Plus提供的updateBatchById方法,将多条记录一次性更新到数据库中。示例代码如下: List<User> userList = new ArrayList<>(); // 修改多条记录的信息 userMapper.updateBatchById(userList); 需要注意的是,批量插入更新的记录数不能太大,否则可能会导致数据库性能下降。建议在实际应用中根据具体情况进行调整。 ### 回答2: Mybatis-plus是一款基于Mybatis的增强工具,它提供了许多实用的功能来简化开发,其中就包括批量插入更新操作。 在实现批量插入更新操作时,我们通常会遵循以下步骤: 1. 创建一个实体类,该实体类需要继承Mybatis-plus提供的Model类,并定义需要插入更新的字段属性。 2. 创建一个Mapper接口,该接口需要继承Mybatis-plus提供的BaseMapper接口,并定义批量插入更新的方法。 3. 在该Mapper接口中实现批量插入更新操作的SQL语句。 4. 在Service中调用Mapper接口中的批量插入更新方法,传入需要插入更新的数据集合即可。 下面是一个示例代码: 1. 定义一个实体类: ``` @Data @TableName("user") public class User extends Model<User> { @TableId(value = "id", type = IdType.AUTO) private Long id; private String name; private Integer age; } ``` 2. 创建一个Mapper接口: ``` public interface UserMapper extends BaseMapper<User> { void batchInsert(List<User> userList); void batchUpdate(List<User> userList); } ``` 3. 实现批量插入更新操作的SQL语句: ``` public void batchInsert(List<User> userList) { SqlSession sqlSession = sqlSessionTemplate.getSqlSessionFactory().openSession(ExecutorType.BATCH); UserMapper mapper = sqlSession.getMapper(UserMapper.class); for (User user : userList) { mapper.insert(user); } sqlSession.flushStatements(); sqlSession.commit(); sqlSession.clearCache(); } ``` ``` public void batchUpdate(List<User> userList) { SqlSession sqlSession = sqlSessionTemplate.getSqlSessionFactory().openSession(ExecutorType.BATCH); UserMapper mapper = sqlSession.getMapper(UserMapper.class); for (User user : userList) { mapper.updateById(user); } sqlSession.flushStatements(); sqlSession.commit(); sqlSession.clearCache(); } ``` 4. 在Service中调用Mapper接口中的批量插入更新方法,传入需要插入更新的数据集合即可: ``` @Autowired private UserMapper userMapper; @Transactional public void batchInsert(List<User> userList) { userMapper.batchInsert(userList); } @Transactional public void batchUpdate(List<User> userList) { userMapper.batchUpdate(userList); } ``` 总之,Mybatis-plus提供的批量插入更新操作非常简洁和高效,使用起来也比较方便,可以有效地提高开发效率。 ### 回答3: Mybatis-plus是一个基于Mybatis框架的增强工具,在Mybatis的基础上扩展并简化了一些操作,使得使用者可以更加便捷地进行数据库操作。Mybatis-plus提供了批量插入更新的功能,可以大大提高数据操作的效率和性能。 批量插入数据 使用Mybatis-plus进行批量插入数据的方法是使用mapper对象的batchInsert方法,示例如下: ```java List<User> userList = new ArrayList<>(); // 添加User对象到userList中 userService.batchInsert(userList); ``` 在上述示例代码中,我们将多个User对象添加到了userList中,然后调用userService的batchInsert方法进行批量插入。 批量更新数据 使用Mybatis-plus进行批量更新数据的方法是使用mapper对象的batchUpdate方法,示例如下: ```java List<User> userList = new ArrayList<>(); // 添加要更新的User对象到userList中 userService.batchUpdate(userList); ``` 在上述示例代码中,我们将多个要更新的User对象添加到了userList中,然后调用userService的batchUpdate方法进行批量更新。 需要注意的是,批量更新操作中要更新的字段必须相同,否则会更新失败。 总结 使用Mybatis-plus进行批量插入更新操作可以大大提高数据操作的效率和性能,但是需要注意,在批量更新操作中要更新的字段必须相同,否则会导致更新失败。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值