• mybatis-plus坑之insert方法


    写在前面

    有天早上我的一个同事,突然跑来告诉我。我们某张表的自增ID变得很大。类似1173776258468638722 这种。这个当然是不能接受的啊。

    着手解决

    然后就开始找问题的原因,一开始我想的是数据库上的问题,我删掉不合理的数据,
    alter table *** AUTO_INCREMENT=20,修改自增ID从20开始。手动插入数据,居然OK。

    那就说明,可能是我们代码insert数据的时候存在的问题。我找到数据库访问层的insert语句处,发现使用的是mybatis-plus,网上查了一下关于这块的东西,发现insert方法在配置的时候,可以指定自增ID的方式。源码中定义有以下几种:

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

    然后我就果断手动配置了一下,

        @TableId(type = IdType.AUTO)
        private Long userId;
    

    ,重启测试,OK。

    也是很奇怪为什么之前的那部分数据的自增ID都是没问题的,突然出现这个,也是很困惑

    总结,出现这个问题的原因,还是因为自己技术不熟练啦~~

  • 相关阅读:
    POJ1806 Manhattan 2025
    POJ1258 AgriNet【最小生成树】
    POJ1789 Truck History【最小生成树】【终于AC了】
    memset的用法
    HDOJ1106 排序
    POJ2965
    414某OJ竞赛题
    HDOJ1745 I hate it【线段树】
    HDOJ2795 Billboard【线段树】
    蓝桥杯o(︶︿︶)o 唉
  • 原文地址:https://www.cnblogs.com/liuge36/p/12614719.html
Copyright © 2020-2023  润新知