MyBatis-Plus主键生成策略
时间: 2023-05-17 12:04:31 浏览: 117
MyBatis-Plus支持多种主键生成策略,包括自增、UUID、雪花算法等。可以通过在实体类上使用注解来指定主键生成策略,例如使用@TableId注解来指定主键生成策略为自增。同时,MyBatis-Plus还提供了一些默认的主键生成策略,例如使用@TableId注解但不指定主键生成策略时,默认使用雪花算法生成主键。
相关问题
Mybatis-Plus主键生成策略
Mybatis-Plus提供了多种主键生成策略,包括自增、UUID、雪花算法等。其中,雪花算法是一种分布式系统中常用的主键生成策略,可以保证在分布式系统中生成的主键不重复。具体实现方式是通过使用机器ID、数据中心ID、时间戳等信息生成一个64位的二进制数,再将其转换为字符串作为主键。在Mybatis-Plus中,使用雪花算法生成主键的示例如下:
```java
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;
@Data
public class User {
@TableId(type = IdType.ASSIGN_ID) // 指定主键生成策略为雪花算法
private Long id;
private String name;
private Integer age;
}
```
在上述示例中,使用了`@TableId`注解指定了主键生成策略为雪花算法,并且使用了`IdType.ASSIGN_ID`枚举类型来表示。除了雪花算法外,Mybatis-Plus还支持其他多种主键生成策略,具体可以参考官方文档。
mybatis-plus主键生成策略 选择
MyBatis-Plus提供了多种主键生成策略可供选择。以下是几种常见的生成策略:
1. 自增主键(`AUTO`):数据库自动生成主键,适用于MySQL、SQL Server等数据库。使用`@TableId(type = IdType.AUTO)`注解可以指定自增主键。
2. 雪花算法(`ASSIGN*** = IdType.ASSIGN_ID)`注解可以指定雪花算法。
3. UUID(`UUID`):使用Universally Unique Identifier (UUID)生成主键,适用于需要全局唯一标识的场景。使用`@TableId(type = IdType.UUID)`注解可以指定UUID。
4. 用户自定义(`INPUT`):使用用户指定的值作为主键,适用于需要手动指定主键的场景。使用`@TableId(type = IdType.INPUT)`注解可以指定自定义主键。
除了上述策略外,MyBatis-Plus还提供了其他的主键生成策略,如雪花算法(`ID_WORKER`)、字符串全局唯一ID(`ID_WORKER_STR`)等。你可以根据具体需求选择适合的主键生成策略。
阅读全文