mybatisplus自动生成id

在 MyBatis-Plus 中,自动生成 ID 通常是通过数据库的自增(Auto Increment)字段来实现的。MyBatis-Plus 提供了几种方式来支持自动生成 ID。以下是一些常用的方法:

  1. 使用数据库自增主键

如果你的数据库表设计为使用自增主键,例如在 MySQL 中,你的表可以这样定义:

```sql

CREATE TABLE example_table (

id BIGINT AUTO_INCREMENT PRIMARY KEY,

name VARCHAR(255) NOT NULL

);

```

在这种情况下,当你插入记录时,数据库会自动为 `id` 字段生成一个唯一的值。在 MyBatis-Plus 中,你不需要做任何特殊设置来使用这种自增主键。只需确保你的实体类中的 ID 字段与数据库表中的列对应,并且使用了正确的数据类型(例如 `Long` 类型)。

  1. 使用雪花算法(Snowflake)或其他自定义 ID 生成策略

如果你需要更复杂的 ID 生成策略,比如使用雪花算法(Snowflake)来生成全局唯一的 ID,你可以通过以下步骤实现:

添加依赖

首先,确保你的项目中包含了 MyBatis-Plus 的依赖,以及任何你选择的 ID 生成库的依赖。例如,如果你使用雪花算法,你可以添加以下依赖到你的 `pom.xml`:

```xml

<dependency>

<groupId>com.github.binarywang</groupId>

<artifactId>java-snowflake</artifactId>

<version>最新版本</version>

</dependency>

```

配置 ID 生成器

然后,你可以创建一个 ID 生成器的 Bean,并在其中实现自定义的 ID 生成逻辑。例如,使用雪花算法:

```java

import com.github.binarywang.tinyid.generator.impl.SnowflakeGenerator;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;

@Configuration

public class IdGeneratorConfig {

@Bean

public SnowflakeGenerator snowflakeGenerator() {

return new SnowflakeGenerator(1, 1); // 根据实际数据中心ID和机器ID调整参数

}

}

```

在实体类中使用 ID 生成器

在你的实体类中,你可以使用 `@TableId` 注解并指定 `type` 属性为 `ASSIGN_ID` 来使用雪花算法:

```java

import com.baomidou.mybatisplus.annotation.TableId;

import com.baomidou.mybatisplus.annotation.IdType;

import java.io.Serializable;

public class ExampleEntity implements Serializable {

@TableId(type = IdType.ASSIGN_ID) // 使用雪花算法生成ID

private Long id;

private String name;

// getters and setters...

}

```

  1. 使用 UUID 生成策略

如果你希望使用 UUID 作为主键,MyBatis-Plus 也支持这种策略:

```java

import com.baomidou.mybatisplus.annotation.TableId;

import com.baomidou.mybatisplus.annotation.IdType;

import java.io.Serializable;

import java.util.UUID;

public class ExampleEntity implements Serializable {

@TableId(type = IdType.ASSIGN_UUID) // 使用UUID作为ID生成策略

private String id; // 注意这里使用String类型存储UUID字符串形式

private String name;

// getters and setters...

}

```

结论

选择哪种 ID 生成策略取决于你的具体需求。对于大多数场景,使用数据库自增主键是最简单和最有效的。如果你需要更复杂的 ID 生成策略,比如全局唯一性或者特定的格式要求,那么实现自定义的 ID 生成器可能是更好的选择。MyBatis-Plus 的灵活性和扩展性允许你轻松地实现这些需求

相关推荐
xieliyu.4 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
明夜之约5 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee5 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Jinkxs5 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
辣机小司5 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
fangdengfu1236 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
云烟成雨TD6 小时前
Spring AI 1.x 系列【51】可观测性技术选型
java·人工智能·spring
星越华夏6 小时前
ESP32-CAM图像传输项目说明文档
java·后端·struts·esp32
Jinkxs7 小时前
Java 跨域14-Java 与区块链(Hyperledger)集成
java·开发语言·区块链
晨曦中的暮雨8 小时前
Golang速通(Javaer版)
java·开发语言·后端·golang