小书MybatisPlus第6篇

您所在的位置:网站首页 mybatisplus映射timestamp报错oracle 小书MybatisPlus第6篇

小书MybatisPlus第6篇

2023-06-24 08:51| 来源: 网络整理| 查看: 265

小书MybatisPlus第6篇-主键生成策略精讲

2023-6-19 阅读次数:12

MybatisPlus,主键

小书MybatisPlus第6篇-主键生成策略精讲

本文为mybatis系列文档的第6篇,前5篇请访问下面的网址。

小书MybatisPlus第1篇-整合SpringBoot快速开始增删改查 小书MybatisPlus第2篇-条件构造器的应用及总结 小书MybatisPlus第3篇-自定义SQL 小书MybatisPlus第4篇-表格分页与下拉分页查询 小书MybatisPlus第5篇-Active Record模式精讲

Mybatis Plus 为我们提供了三种设置 主键生成策略的方式。它们的优先级顺序是:局部注解 > 全局 > 默认(雪花算法)。下面我们来一一介绍

一、默认主键生成策略:雪花算法

Mybatis Plus如果不做任何主键策略配置,默认使用的是雪花算法。该策略会根据雪花算法生成主键ID,主键类型为Long或String(具体到MySQL数据库就是BIGINT和VARCHAR),该策略使用接口IdentifierGenerator的方法nextId(默认实现类为DefaultIdentifierGenerator雪花算法)

snowflake算法是Twitter开源的分布式ID生成算法,结果是一个long类型的ID 。其核心思想:使用41bit作为毫秒数,10bit作为机器的ID(5bit数据中心,5bit的机器ID),12bit作为毫秒内的流水号(意味着每个节点在每个毫秒可以产生4096个ID),最后还有一个符号位,永远是0。

二、自定义主键策略

mybatis-plus3.3.0以后,主要有五种主键生成策略。

public enum IdType { /** * 数据库ID自增,数据库需要支持主键自增(如MySQL),并设置主键自增 */ AUTO(0), /** * 该类型为未设置主键类型,默认使用雪花算法生成 */ NONE(1), /** * 用户输入ID,数据类型和数据库保持一致就行 *

该类型可以通过自己注册自动填充插件进行填充

*/ INPUT(2), /* 以下3种类型、只有当插入对象ID 为空,才自动填充。 */ /** * 全局唯一ID (idWorker),数值类型 数据库中也必须是数值类型 否则会报错 */ ID_WORKER(3), /** * 全局唯一ID (UUID,不含中划线) */ UUID(4), /** * 字符串全局唯一ID (idWorker 的字符串表示),数据库也要保证一样字符类型 */ ID_WORKER_STR(5); } 三、局部注解配置策略

我们针对主键设置主键策略使用注解方式为

@TableId(type = IdType.AUTO) private long userId; 四、全局配置策略 mybatis-plus: global-config: db-config: id-type: auto 五、扩展使用 5.1.INPUT用户输入ID策略的用法

其中需要和大家特殊介绍的是:Input(用户输入ID),这个ID来源可以有两种

用户自己设置ID,并在insert之前SET主键的值 一些有序列的数据库,比如Oracle,SQLServer等,针对这些数据库我们可以通过序列填充ID字段

Mybatis-Plus 内置了如下数据库主键序列(如果内置支持不满足你的需求,可实现 IKeyGenerator 接口来进行扩展):

DB2KeyGenerator H2KeyGenerator KingbaseKeyGenerator OracleKeyGenerator PostgreKeyGenerator

以Oracle 的Sequence使用方法为例,使用方法如下:首先添加@Bean

@Bean public OracleKeyGenerator oracleKeyGenerator(){ return new OracleKeyGenerator(); }

然后实体类配置主键 Sequence,指定主键策略为 IdType.INPUT 即可,

@Data @KeySequence(value = "SEQ_USER" , clazz = Long.class) public class User { @TableId(value = "ID",type = IdType.INPUT) private Integer id;

版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://www.cnblogs.com/zimug/p/13364279.html,作者:字母哥博客,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至[email protected]沟通。

上一篇:OpenStack排错记录---ResourceProviderCreationFailed和You are not authorized to perform the requested actio

下一篇:Linux内核之IO1: I/O模型



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3