myatisplus的saveOrUpdate的提交总是update问题

 更新时间:2023年11月20日 15:17:31   作者:勤快的小蚂蚁  
这篇文章主要介绍了myatisplus的saveOrUpdate的提交总是update问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

背景

很多朋友,想把新增和编辑做在一起。

没想到自己遇到坑了,

自己的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都不相同,

所以如果不使用条件选择器,一定是插入。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java解析xml的四种方法汇总

    Java解析xml的四种方法汇总

    XML在不同的语言里解析方式都是一样的,只不过实现的语法不同而已。java中基本的解析方式有四种,DOM解析、sax解析、JDOM解析和DOM4J解析,下面我们就来详细探讨下这四种方式
    2016-05-05
  • 详解Java动态字节码技术

    详解Java动态字节码技术

    Java字节码增强指的是在Java字节码生成之后,对其进行修改,增强其功能,可减少冗余代码,提高性能等。本文将详细介绍Java动态字节码技术。
    2021-05-05
  • JavaFx Tooltip悬浮提示使用及自定义代码详解

    JavaFx Tooltip悬浮提示使用及自定义代码详解

    本篇是基于TornadoFx框架对Tooltip组件进行讲解,使用Kotlin语言,和传统Java使用有所区别,本章节包括对tooltip的样式定制化以及指定窗口显示,对JavaFx Tooltip悬浮提示使用及自定义相关知识感兴趣的朋友一起看看吧
    2021-12-12
  • 如何使用Java在excel单元格中设置超链接

    如何使用Java在excel单元格中设置超链接

    这篇文章主要介绍了如何使用Java在excel单元格中设置超链接,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • java poi导入纯数字等格式问题及解决

    java poi导入纯数字等格式问题及解决

    这篇文章主要介绍了java poi导入纯数字等格式问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • jmeter中json提取器如何提取多个参数值

    jmeter中json提取器如何提取多个参数值

    关于jmeter中的正则表达式及json提取器可以提取响应值,但是实际可以需要上个接口的多个响应值,本文就详细的介绍一下如何使用,感兴趣的可以了解一下
    2021-11-11
  • Spring配置多个数据源并实现数据源的动态切换功能

    Spring配置多个数据源并实现数据源的动态切换功能

    这篇文章主要介绍了Spring配置多个数据源并实现数据源的动态切换功能,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • java调用opencv身份证号识别详解

    java调用opencv身份证号识别详解

    这篇文章主要为大家详细介绍了java如何调用opencv实现身份证号的识别,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-03-03
  • 详解Spring的两种代理方式:JDK动态代理和CGLIB动态代理

    详解Spring的两种代理方式:JDK动态代理和CGLIB动态代理

    这篇文章主要介绍了详解Spring的两种代理方式:JDK动态代理和CGLIB动态代理,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 全面解读Java NIO(看这篇就够了)

    全面解读Java NIO(看这篇就够了)

    Java NIO是Java1.4之后推出来的一套IO接口,NIO提供了一种完全不同的操作方式, NIO支持面向缓冲区的、基于通道的IO操作,这篇文章主要介绍了Java NIO详解(看这篇就够了),需要的朋友可以参考下
    2023-05-05

最新评论