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

相关推荐
华仔啊11 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
xiaoye201814 小时前
Lettuce连接模型、命令执行、Pipeline 浅析
java
beata17 小时前
Java基础-18:Java开发中的常用设计模式:深入解析与实战应用
java·后端
Seven9717 小时前
剑指offer-81、⼆叉搜索树的最近公共祖先
java
雨中飘荡的记忆1 天前
保证金系统入门到实战
java·后端
Nyarlathotep01131 天前
Java内存模型
java
暮色妖娆丶2 天前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP2 天前
MyBatis-参数处理与查询结果映射
java
狂奔小菜鸡2 天前
Day40 | Java中的ReadWriteLock读写锁
java·后端·java ee