解决mybatis-plus新增数据自增ID变无序问题

 更新时间:2023年07月15日 09:45:14   作者:某猿蚊常叮  
这篇文章主要介绍了解决mybatis-plus新增数据自增ID变无序问题,具有很好的参考价值,希望对大家有所帮助。

mybatis-plus新增数据自增ID变无序

问题描述

在测试mybatis-plus时, 发现新增接口,新增出来的数据id变的巨长且无序, 经过查询,原来是实体类少了注解, 下面是未添加之前的

@Data
public class User {
    private Integer id;
    private String username;
    // 忽略,不传到前端
    @JsonIgnore
    private String password;
    private String nickname;
    private String email;
    private String phone;
    private String address;
}

解决

这里需要在id上指定, 自增的设定: @TableId(value = "id", type = IdType.AUTO), 如下

@Data
public class User {
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;
    private String username;
    // 忽略,不传到前端
    @JsonIgnore
    private String password;
    private String nickname;
    private String email;
    private String phone;
    private String address;
}

但下次新增的时候, id会从你最后一次新增的那个id开始自增, 所以我们的将mysql的id进行重置, 重置方法, 这里就采用比较简单的

1. 删除错误id数据

首先将之前新增的无序的id数据删除

2. alter table重置自增ID

例如:

DELETE FROM USER WHERE ID = 4;

使用 ALTER TABLE 重置自增 ID:

ALTER TABLE table_name AUTO_INCREMENT = value;
  • table_name为当前要重置自增 ID 的表名。
  • value必须是大于当前表中最大 ID 数,本示例中当前表最大数为 2,我们可以设置成 3。

至此, 后面就可以愉快的写代码了

mybaits-plus新增数据明明没有输入id的值(id自增)却报错

mybaits-plus新增数据明明没有输入id的值(id自增)却报错???

新增数据

{
    "name": "第二fff会议室",
    "isApprove": 1,
    "remarks": "第1会议室"
}

报错信息

Data truncation: Out of range value for column 'id' at row 1

明明没有输入id的值

并且数据库表中已经设置了id为自增

在这里插入图片描述

百度资料,终于找到了原因

这里贴图展示原因:

mybatis-plus开启主键雪花策略,生成19位随机字符串,数据库中的主键字段为int类型,长度小于19位。解决:将数据库中表的主键字段设置为bigint类型

在这里插入图片描述

结果成功

{
    "code": 201,
    "data": true,
    "message": "请求成功"
}

MyBatisPlus自增id怎么设置成int自增呢?

使用 mybatis-plus的insert方法,在底层会默认生成一个Long类型的UUID,这就导致跟数据库里面类型不一致导致错误,我们首先要做的是要把这个默认自增的主键给禁了

1.在实体类 id上面加一个注解,并且实体类继承Model

@TableId(value = “id”,type = IdType.INPUT)
private Integer id;

2.然后在重写这个方法

@Override
protected Serializable pkVal() {
return this.id;
}

3.不要忘记了在数据库设计表中勾选自动增长,不然会报错:

在这里插入图片描述

在这里插入图片描述

总结

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

相关文章

  • System.getProperty(“line.separator“)含义及意义详解

    System.getProperty(“line.separator“)含义及意义详解

    这篇文章主要介绍了System.getProperty(“line.separator“)含义,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-05-05
  • idea 右键项目没有run 运行选项

    idea 右键项目没有run 运行选项

    这篇文章主要介绍了idea 右键项目没有run 运行选项,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Java实现消消乐中的消除功能

    Java实现消消乐中的消除功能

    这篇文章主要为大家详细介绍了Java实现消消乐中的消除功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • java实现CSV文件导入与导出功能

    java实现CSV文件导入与导出功能

    这篇文章主要为大家详细介绍了java实现CSV文件导入与导出,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • 解析Java编程中设计模式的开闭原则的运用

    解析Java编程中设计模式的开闭原则的运用

    这篇文章主要介绍了解析Java编程中设计模式的开闭原则的运用,开闭原则多应用于Java程序的扩展开发方面,需要的朋友可以参考下
    2016-02-02
  • Java线程启动为什么要用start()而不是run()?

    Java线程启动为什么要用start()而不是run()?

    这篇文章主要介绍了线程启动为什么要用start()而不是run()?下面文章围绕start()与run()的相关资料展开详细内容,具有一定的参考价值,西药的小火熬版可以参考一下,希望对你有所帮助
    2021-12-12
  • SpringBoot使用AOP记录接口操作日志详解

    SpringBoot使用AOP记录接口操作日志详解

    这篇文章主要为大家详细介绍了SpringBoot使用AOP记录接口操作日志,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • java自定义日期转化类示例

    java自定义日期转化类示例

    这篇文章主要介绍了java自定义日期转化类示例,需要的朋友可以参考下
    2014-05-05
  • Jmeter基于JDBC请求实现MySQL数据库测试

    Jmeter基于JDBC请求实现MySQL数据库测试

    这篇文章主要介绍了Jmeter基于JDBC请求实现MySQL数据库测试,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Java设计模式之单例设计模式解析

    Java设计模式之单例设计模式解析

    这篇文章主要介绍了Java设计模式之单例设计模式解析,设计模式是在大量的实践中总结和理论化之后优选的代码结构、编程风格、以及解决问题的思考方式,设计模式免去我们自己再思考和摸索,需要的朋友可以参考下
    2023-11-11

最新评论