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

相关推荐
时艰.1 小时前
电商订单系统设计与实现
java
sheji34161 小时前
【开题答辩全过程】以 基于Java的网上书店销售系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
石去皿2 小时前
数据结构与算法面试核心考点精要
java·算法·面试
学Linux的语莫2 小时前
skills的使用
java·数据库·python
大模型玩家七七2 小时前
关系记忆不是越完整越好:chunk size 的隐性代价
java·前端·数据库·人工智能·深度学习·算法·oracle
一 乐2 小时前
林业资源管理|基于java + vue林业资源管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·林业资源管理系统
lipiaoshuigood2 小时前
微服务生态组件之Spring Cloud LoadBalancer详解和源码分析
java·spring cloud·微服务
Geoking.2 小时前
什么是乐观锁?原理、实现方式与实战详解
java·开发语言
小光学长3 小时前
基于ssm的校园约自习网站23i21xj4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring