Mybatis-plus id生成策略

目录

1.1、为什么选择不同的id生成策略

1.2、策略种类

1.2.1、AUTO(自动增长策略)

1.2.3、ASSIGN_ID(雪花算法)

1.2.4、ASSIGN_UUID(不含中划线的UUID)

1.2.5、NONE(无状态)

1.3、注意


1.1、为什么选择不同的id生成策略

1、Mybatis-plus提供了多种主键生成策略, 可以在Pojo类中主键上加注解进行配置,例如数据库主键自增 @TableId(type=IdType.AUTO)

2、不同的表应用不同的id生成策略:

  • 日志:自增(1,2,3,4,……)
  • 购物订单:特殊规则(FQ23948AK3843)
  • 外卖单:关联地区日期等信息(10 04 20200314 34 91)
  • 关系表:可省略id
  • ……

3、表现形式

  • 名称 @TableId
  • 类型 属性注解
  • 位置 模型类中用于表示主键的属性定义上方
  • 作用 设置当前类中主键属性的生成策略
  • 相关属性
    • value(默认):设置数据库表主键名称
    • type:设置主键属性的生成策略,值参照IdType的枚举值

1.2、策略种类

1.2.1、AUTO(自动增长策略)

AUTO自动增长策略,这个配合数据库使用,Mysql可以,但是Oracle不行。不配合会报错。

在主键字段上加上 @TableId(type = IdType.AUTO)

@Data
public class UserInfo {
    //指定主键使用数据库ID自增策略
    @TableId(type = IdType.AUTO)
    private Integer id;
    private String userName;
    private String passWord;
}

1.2.2、Input(自定义输入策略)

自定义输入策略:如果不想使用数据库的自增主键,也可以使用INPUT进行自己传递主键即可,进行插入工作,但在插入之前一定要检查数据库是否已经存在了该主键。

Mybatis-Plus 内置了如下数据库主键序列:

DB2KeyGenerator
H2KeyGenerator
KingbaseKeyGenerator
OracleKeyGenerator
PostgreKeyGenerator

使用方法如下所示:

首先添加@Bean

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

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

@Data
@KeySequence(value = "SEQ_ACL_ROLE" , clazz = Integer.class)
public class AclUser implements Serializable {
    private static final long serialVersionUID = 780903014942735924L;
    @TableId(value = "ID",type = IdType.INPUT)
    private Integer id;

1.2.3、ASSIGN_ID(雪花算法)

如果不设置type值,默认则使用IdType.ASSIGN_ID策略(自 3.3.0 起)。该策略会使用雪花算法自动生成主键 ID,主键类型为 Long 或 String。

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

使用方法
指定主键生成策略使用雪花算法(默认策略)

@Data
public class UserInfo {
    //指定主键生成策略使用雪花算法(默认策略)
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;
    private String userName;
    private String passWord;
}

1.2.4、ASSIGN_UUID(不含中划线的UUID)

如果使用 IdType.ASSIGN_UUID 策略,则会自动生成不含中划线的 UUID 作为主键,主键类型为 String

@Data
public class UserInfo {
    //指定主键生成策略为不含中划线的UUID
    @TableId(type = IdType.ASSIGN_UUID)
    private String id;
    private String userName;
    private String passWord;
}

1.2.5、NONE(无状态)

如果使用 IdType.NONE 策略,表示未设置主键类型(注解里等于跟随全局,全局里约等于 INPUT

假设我们希望默认全部都使用 AUTO 策略(数据库ID自增),那么可以在 application.properties 中添加如下配置进行修改:

mybatis-plus.global-config.db-config.id-type=auto

1.3、注意

注意事项:Mysql 的默认值只有在insert语句中没有这个字段时才会生效,如果insert中有插入该字段而该字段取值又为nullnull值将被插入到表中,默认值此时失效。使用Mybatis操作也是一样的道理,只要这个实体里面含有这个字段,并且值为null,则不会插入默认值。

你可能感兴趣的:(mybatis-plus,mybatis,java,数据库)