MybatisPlus生成主键策略方法
MybatisPlus生成主键策略方法
全局id生成策略【因为是全局id所以不推荐】
SpringBoot集成Mybatis-Plus
在yaml配置文件中添加MP配置
mybatis-plus: global-config: db-config: #主键类型(auto:"自增id",assign_id:"全局唯一id(雪花算法,Long或者String类型)", assign_uuid:"全局唯一id(无中划线的uuid)",input:"自行设置id,默认null",none:"不设置主键id") id-type: assign_id
局部id生成策略【局部id非常推荐】
在实体类当中使用@TableId注解配置id生成类型
@TableId(type = IdType.AUTO) private String id;
注意事项:
-
同时配置了这两种策略时,局部字段的ID生成策略优先级高于全局的id生成策略
-
使用雪花算法生成ID后,再次切换为主键自增的ID生成策略后会导致起始序列过大(没有重置起始序列值)
-
另外如果原先指定了@TableId(type = IdType.AUTO),然后去除这部分代码,会发生Tuncate操作(即清空表并重置ID起始值)
如果大家没有用到MybaitsPlus,也可以用java自带的生成方法
因为一般数据库主键为String类型,所以接收类型为String,生成的uuid数据包含-,所以要去掉-,
java.util.UUID.randomUUID().toString().replace("-", "").toLowerCase();
也可以用hutool
中的生成方法,下面是以int类型为例子
int context = Math.abs(IdUtil.fastSimpleUUID().hashCode());
也可以用当前时间戳+随机id的形式生成唯一的,下面是以String类型为例子,
(当并发创建时有可能会重复所以建议使用雪花算法)
Date date = new Date(); String context = DateUtil.format(date,"yyyyMMdd") +Math.abs(IdUtil.fastSimpleUUID().hashCode());
使用hutool需要导入依赖
<!-- Hutool--> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.7.19</version> </dependency>
当然这些只是我的建议,大家可以去找找其他的方法。
有知道其他方法的小伙伴们欢迎在底下留言,本人小白一枚轻喷!
分类:
Mybatis-Plus知识点
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义