myatisplus的saveOrUpdate的提交总是update

7 篇文章 0 订阅

背景

很多朋友,想把新增和编辑做在一起。
没想到自己遇到坑了,
自己的saveOrUpdate的提交总是update。

控制台sql输出

UPDATE t_course_type  SET course_type_name=?,
create_time=?,
create_user=?,
update_time=?,
update_user=?

报错

com.baomidou.mybatisplus.core.exceptions.MybatisPlusException:  Prohibition of table update operation

官方文档

// TableId 注解存在更新记录,否插入一条记录
boolean saveOrUpdate(T entity);
// 根据updateWrapper尝试更新,否继续执行saveOrUpdate(T)方法
boolean saveOrUpdate(T entity, Wrapper<T> updateWrapper);

分析

发现上面的sql没有where条件。
以为是新增操作,没有id,主键是自增的,就加了个判断
ObjectUtils.isNotEmpty(courseTypeId)
发现是updateWrapper的eq方法 不能加condition参数。

错误方式

updateWrapper.eq(ObjectUtils.isNotEmpty(courseTypeId), CourseTypeEntity::getCourseTypeId, courseTypeId);

正确方式

去除第一个condition参数。保留2个参数即可。

updateWrapper.eq(CourseTypeEntity::getCourseTypeId, courseTypeId);

成功案例实现源码分享

LambdaUpdateWrapper<CourseTypeEntity> updateWrapper = new LambdaUpdateWrapper<>();
  
        updateWrapper.eq(CourseTypeEntity::getCourseTypeId, courseTypeId);
        
        CourseTypeEntity courseTypeEntity = new CourseTypeEntity();
        if (courseTypeIdNotEmpty) {
            courseTypeEntity.setCourseTypeId(courseTypeId)
                    .setUpdateTime(LocalDateTime.now())
                    .setUpdateUser(username)
                    .setCourseTypeName(courseTypeName)
                    .setCourseCount(courseCount);
        } else {
            courseTypeEntity.setCourseTypeName(courseTypeName)
                    .setCreateTime(LocalDateTime.now())
                    .setCreateUser(username)
                    .setUpdateTime(LocalDateTime.now())
                    .setUpdateUser(username);
        }
        
        boolean saveOrUpdate = this.saveOrUpdate(courseTypeEntity, updateWrapper);

总结

要去了解这个saveOrUpdate的源码的处理机制。

源码

    default boolean saveOrUpdate(T entity, Wrapper<T> updateWrapper) {
        return this.update(entity, updateWrapper) || this.saveOrUpdate(entity);
    }

因为该方法默认是使用实体对象的id去匹配,
如果有就更新,
如果没有就插入。
对于主键自增的场景,
一般不会手动设置id,每一次的id都不相同,
所以如果不使用条件选择器,一定是插入。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勤快的小蚂蚁

奖励下我呗!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值