快速解决 MyBatis-Plus 中 ID 自增问题(推荐)

 更新时间:2025年02月07日 14:37:52   作者:迷迷的k  
本文介绍了MyBatis-Plus中自动生成ID过长导致的问题及解决方法,结合示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧

MyBatis-Plus 中自动生成的 ID 过长,可能导致以下问题的出现:

  • 由于属性的 ID 是由 mp 内部的 UUID 生成,比如使用 Integer类型 将存不进去
  • 当后端传入 mp 雪花算法自动生成的 ID 时,前端接收的时候可能会导致精度的损失

问题一:由于属性的 ID 是由 mp 内部的 UUID 生成,比如使用 Integer类型 将存不进去

报错信息如下所示:

ested exception is org.apache.ibatis.reflection.ReflectionException: Could not set property 'id' of 'class com.xxx' with value '111042370348747XXXX Cause: java.lang.IllegalArgumentException: java.lang.ClassCastException@14041406

解决方法:

将 ID 字段类型改为 long,这样就能保证有足够位数放入生成的 ID

问题二:当后端传入 mp 雪花算法自动生成的 ID 时,前端接收的时候可能会导致精度的损失

解决方法:

第一步:

首先在对应的类的主键属性上,增加以下代码配置

@TableId(value = "id",type = IdType.AUTO)
    private Long id;

type 属性中,其他类型如下: 

AUTO:AUTO(0, “数据库ID自增”),

INPUT:INPUT(1, “用户输入ID”),

ID_WORKER:ID_WORKER(2, “全局唯一ID”),

UUID:UUID(3, “全局唯一ID”),

NONE:NONE(4, “该类型为未设置主键类型”),

ID_WORKER_STR:ID_WORKER_STR(5, “字符串全局唯一ID”);

这里的 @TableId 注解需要添加以下依赖:

这里的版本号最好与 mp 的主依赖的版本保持一致

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus</artifactId>
    <version>版本号</version>
</dependency>

第二步:

将之前的被自增长的ID数据删除

第三步:

在需要解决 mp 自增长的表中,执行以下语句

ALTER TABLE table_name AUTO_INCREMENT = value;
 

其中, table_name 是对应的表名,value 是你需要进行自增的 ID 值

比如:value 赋值为 2,则 mp 下次生成的 ID 则为2,即从 2 开始

自增主键与 UUID 的优缺点

自增主键:

这种方式是使用数据库提供的自增数值型字段作为自增主键

优点:

  • 数据库自动编号,速度快,而且是增量增长,按顺序存放,对于检索非常有利
  • 数字型,占用空间小,易排序,在程序中传递也方便
  • 如果通过非系统增加记录时,可以不用指定该字段,不用担心主键重复问题

缺点 :

  • 因为自动增长,在手动要插入指定ID的记录时会显得麻烦,尤其是当系统与其它系统集成时,需要数据导入时,很难保证原系统的ID不发生主键冲突(前提是老系统也是数字型的)
  • 如果经常有合并表的操作,就可能会出现主键重复的情况很难处理分布式存储的数据表
  • 数据量特别大时,会导致查询数据库操作变慢;此时需要进行数据库的水平拆分,划分到不同的数据库中,那么当添加数据时,每个表都会自增长,导致主键冲突

UUID:

优点:

能够保证独立性,程序可以在不同的数据库间迁移,效果不受影响;保证生成的ID不仅是表独立的,而且是库独立的,这点在你想切分数据库的时候尤为重要

缺点:

  • 比较占地方,和INT类型相比,存储一个UUID要花费更多的空间
  • 使用UUID后,URL显得冗长,不够友好
  • Join 操作性能比 int 要低
  • UUID做主键将会添加到表上的其他索引中,因此会降低性能

到此这篇关于解决 MyBatis-Plus 中 ID 自增问题的文章就介绍到这了,更多相关MyBatis-Plus ID 自增内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决kafka:org.apache.kafka.common.errors.TimeoutException问题

    解决kafka:org.apache.kafka.common.errors.TimeoutException问题

    这篇文章主要介绍了解决kafka:org.apache.kafka.common.errors.TimeoutException问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • RabbitMQ之死信队列深入解析

    RabbitMQ之死信队列深入解析

    这篇文章主要介绍了RabbitMQ之死信队列深入解析, 死信,顾名思义就是无法被消费的消息,字面意思可以这样理解,一般来说,producer将消息投递到 broker 或者直接到 queue 里了,consumer 从 queue 取消息进行消费,需要的朋友可以参考下
    2023-09-09
  • Java关于远程调试程序教程(以Eclipse为例)

    Java关于远程调试程序教程(以Eclipse为例)

    这篇文章主要介绍了Java关于远程调试程序教程(以Eclipse为例),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • MyBatis更新时新值为null时,updateById()更新失败问题

    MyBatis更新时新值为null时,updateById()更新失败问题

    这篇文章主要介绍了MyBatis更新时新值为null时,updateById()更新失败问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • java制作简单的坦克大战

    java制作简单的坦克大战

    坦克大战是我们小时候玩红白机时代的经典游戏,看到有不少小伙伴都使用各种语言实现了一下,手痒痒,也使用java做的一个比较简单的坦克大战,主要面向于学过Java的人群,与学了一段时间的人,有利于面向对象思想的提高,推荐给大家。
    2015-03-03
  • Spring中的ClassPathXmlApplicationContext源码详解

    Spring中的ClassPathXmlApplicationContext源码详解

    这篇文章主要介绍了Spring中的ClassPathXmlApplicationContext源码详解,ApplicationContext的主要实现类是ClassPathXmlApplicationContext和FileSystemXmlApplicationContext,前者默认从类路径加载配置文件,后者默认从文件系统中装载配置文件,需要的朋友可以参考下
    2023-12-12
  • Java线程池框架核心代码解析

    Java线程池框架核心代码解析

    这篇文章主要针对Java线程池框架核心代码进行详细解析,分析Java线程池框架的实现ThreadPoolExecutor,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • Java消息摘要算法MAC实现与应用完整示例

    Java消息摘要算法MAC实现与应用完整示例

    这篇文章主要介绍了Java消息摘要算法MAC实现与应用,结合完整实例形式分析了java消息摘要算法MAC的概念、原理、实现方法及相关操作注意事项,需要的朋友可以参考下
    2019-09-09
  • java反编译工具jd-gui使用详解

    java反编译工具jd-gui使用详解

    JD-GUI是一个独立的图形实用程序,显示“.class”文件的Java源代码,本文主要介绍了java反编译工具jd-gui使用详解,具有一定的参考价值,感兴趣的可以了解一下
    2023-09-09
  • es创建索引和mapping的实例

    es创建索引和mapping的实例

    这篇文章主要介绍了es创建索引和mapping的实例,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02

最新评论