目录
Mybatis Plus 为我们提供了三种设置 主键生成策略的方式。它们的优先级顺序是:局部注解 > 全局 > 默认(雪花算法)
默认的主键生成策略:雪花算法
mp如果不做任何主键策略配置,默认使用的都是雪花算法,该策略会根据俄雪花算法生成主键ID,主键类型为Long或者为String类型的,对应在数据库的字段就是BIGINT和VARCHAR
该策略使用接口IdentifierGenerator的方法nextId
默认实现类为DefaultIdentifierGenerator雪花算法
自定义主键策略
mybatis-plus3.3.0以后,主要有五种主键生成策略
public enum IdType {
/**
* 数据库ID自增,数据库需要支持主键自增(如MySQL),并设置主键自增
*/
AUTO(0),
/**
* 该类型为未设置主键类型,默认使用雪花算法生成
*/
NONE(1),
/**
* 用户输入ID,数据类型和数据库保持一致就行
* <p>该类型可以通过自己注册自动填充插件进行填充</p>
*/
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 Id;
全局配置策略
写在yml之中,代码如下
mybatis-plus:
global-config:
db-config:
id-type: auto