Mybatis-plus插入数据遇到主键没有默认值的情况

 更新时间:2023年11月03日 15:24:05   作者:讓丄帝愛伱  
这篇文章主要介绍了Mybatis-plus插入数据遇到主键没有默认值的情况,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

Mybatis-plus插入数据遇到主键没默认值

新增数据时报

java.sql.SQLException: Field 'id' doesn't have a default value

mybatis-plus的insert方法,在底层会默认生成一个Long类型的UUID,这就导致跟数据库里面类型不一致,把数据库默认自增的主键给禁了

主键生成方式类型如下(IdType):

AUTO(0, "数据库ID自增"),
INPUT(1, "用户输入ID"),
ID_WORKER(2, "全局唯一ID"),
UUID(3, "全局唯一ID"),
NONE(4, "该类型为未设置主键类型"),
ID_WORKER_STR(5, "字符串全局唯一ID");

设置主键的生成方式

@TableId(value = "id",type = IdType.INPUT) // 主键手动输入

mybatis-plus插入数据时,关于id没有赋值,系统自动赋值,并报错Could not set property ‘id‘ of ‘***‘ with value

赶时间的同学可以直接看文章最后的结果

创建了一张表,表里面有id字段,但是并没有声明它为主键

对应java实体类为

然后开始inset,随便写个伪代码

User user = new User();
user.setId("");
user.setName("测试");
this.insert(user);

然后就报错了,一看报错信息是

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.reflection.ReflectionException:
Could not set property ‘id’ of 'class User ’ with value ‘1278867511785242626’
Cause: java.lang.IllegalArgumentException: argument type mismatch

what??

我并没有设置id啊,看着这有规则数字,很像是mybatis-plus自动生成的主键值

然后就翻了翻mybatis-plus的大致源码,找到idType类

看到mybatis-plus有这5中主键生成类型,一般对应我们数据库表中id的生成类型

比如我设置我得实体类id的生成类型为uuid

以上一般是我们的正常操作

现在的我不想在这个表中建立主键,我想插入数据的时候,先不塞id的值,我就是想写bug(🤭开玩笑啊),这样怎么弄呢

我不添加@TableId注解,不设置id的类型不行了吗,答案是不行的

如果你的实体类中有字段名定义为了“id”,mybatis-plus就默认你这个字段是主键,就算你不定义它的生成类型,mybatis-plus在自动装载的时候会帮你把id设置为默认类型,而默认的idType就是ID_WORKER,全局唯一

那好,我加上主键@TableId

既然我这个表没有主键,我也不想塞值进去,那我把实体里面的id类型设置为

@TableId(type = IdType.NONE)
	private String id;

这个行不行呢,答案还是是不行的,如下

找到TableInfoHelper 这个类,里面有初始化table的方法 initTableId

里面进行了判断,如果idType为NONE,还是会把id的类型设置成全局默认类型ID-WORKER

哈哈,由此可以看出mybatis-plus怕我们忘记设置主键id真是操碎了心啊

好了,上面5中id生成的类型只有input看着可以满足我们的需求了

这个顾名思义就是用户塞什么值就是什么值

我们把idType设置为

@TableId(type = IdType.INPUT)
private String id;

这样我们就可以随意的写入id任何值了,。

总结

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

相关文章

  • icePDF去水印的方法(推荐)

    icePDF去水印的方法(推荐)

    下面小编就为大家带来一篇icePDF去水印的方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • MybatisPlus中的删除和逻辑删除及区别介绍

    MybatisPlus中的删除和逻辑删除及区别介绍

    这篇文章主要介绍了MybatisPlus中的删除和逻辑删除的相关知识,删除又分为逻辑删除和物理删除,那么它们有什么区别呢?在本文给大家详细介绍,感兴趣的朋友跟随小编一起看看吧
    2020-08-08
  • Springboot  jar包 idea 远程调试的操作过程

    Springboot  jar包 idea 远程调试的操作过程

    文章介绍了如何在IntelliJ IDEA中远程调试Spring Boot项目的Jar包,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-11-11
  • Java中常用加密/解密方法详解

    Java中常用加密/解密方法详解

    本文主要介绍了Java中常用加密/解密方法。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • spring framework体系结构及模块jar依赖关系详解

    spring framework体系结构及模块jar依赖关系详解

    在本篇文章里小编给大家整理的是关于spring framework体系结构及模块jar依赖关系,对此有兴趣的朋友们可以学习下。
    2019-09-09
  • MybatisPlus 自定义插件实现拦截SQL修改功能(实例详解)

    MybatisPlus 自定义插件实现拦截SQL修改功能(实例详解)

    这篇文章主要介绍了MybatisPlus 自定义插件实现拦截SQL修改功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-11-11
  • Java中Runnable和Callable分别什么时候使用

    Java中Runnable和Callable分别什么时候使用

    提到 Java 就不得不说多线程了,就算你不想说,面试官也得让你说呀,那说到线程,就不得不说Runnable和Callable这两个家伙了,二者在什么时候使用呢,下面就来和简单讲讲
    2023-08-08
  • jcl与jul log4j1 log4j2 logback日志系统机制及集成原理

    jcl与jul log4j1 log4j2 logback日志系统机制及集成原理

    这篇文章主要介绍了jcl与jul log4j1 log4j2 logback的集成原理,Apache Commons-logging 通用日志框架与日志系统的机制,有需要的朋友可以借鉴参考下
    2022-03-03
  • Java动态循环队列是如何实现的

    Java动态循环队列是如何实现的

    今天带大家学习java队列的相关知识,文章围绕着如何实现Java动态循环队列展开,文中有非常详细的介绍及代码示例,需要的朋友可以参考下
    2021-06-06
  • 浅谈Sharding-JDBC强制路由案例实战

    浅谈Sharding-JDBC强制路由案例实战

    本文主要介绍了浅谈Sharding-JDBC强制路由案例实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07

最新评论