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 的灵活性和扩展性允许你轻松地实现这些需求

相关推荐
吴声子夜歌8 分钟前
TypeScript——基础类型(三)
java·linux·typescript
DynamicsAgg1 小时前
企业数字化底座-k8s企业实践系列第二篇pod创建调度
java·容器·kubernetes
森林里的程序猿猿2 小时前
并发设计模式
java·开发语言·jvm
222you2 小时前
四个主要的函数式接口
java·开发语言
Javatutouhouduan2 小时前
Java全栈面试进阶宝典:内容全面,题目高频!
java·高并发·java面试·java面试题·后端开发·java程序员·java八股文
SEO-狼术2 小时前
RAD Studio 13.1 Florence adds
java
ywf12153 小时前
Spring Boot接收参数的19种方式
java·spring boot·后端
敲代码的瓦龙3 小时前
Java?面向对象三大特性!!!
java·开发语言