mybatis-plus添加数据时id生成问题

在springboot项目中使用了mybatis-plus,数据库表设置的主键自增,但在插入数据时自动生成很大的数,如下图:
在这里插入图片描述

原因:

mybatis-plus默认会生成id,该id是雪花算法生成的id,数据库id字段设置为bigint,其他的字段没有设置值的话,插入操作是不会有值产生

雪花算法

SnowFlake 算法,是 Twitter 开源的分布式 id 生成算法。其核心思想就是:使用一个 64 bit 的 long 型的数字作为全局唯一 id。在分布式系统中的应用十分广泛,且ID 引入了时间戳,基本上保持自增的。

解决办法:

解决方案一

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

  2. 调整数据库id字段类型
    将数据库的id字段的长度(改为20位)

解决方案二

在实体类id上面添加注解@TableId(type = IdType.AUTO)
在这里插入图片描述
在这里插入图片描述
其中
AUTO(0, “数据库ID自增”),
NONE(1, “该类型为未设置主键类型”),
INPUT(2, “用户输入ID”),
ID(3, “全局唯一ID”),
UUID(4, “全局唯一ID”),

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值