当前位置:首页 > 行业动态 > 正文

mybatisplus自动生成主键

MybatisPlus 是一个优秀的持久层框架,它提供了自动生成主键的功能。通过使用 MybatisPlus,开发者可以简化数据库操作,提高开发效率。

MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射,在使用MyBatis时,我们经常会遇到需要自动生成主键的情况,MyBatis自动生成主键的方法是什么呢?本文将详细介绍MyBatis自动生成主键的方法。

mybatisplus自动生成主键  第1张

1. 数据库自增主键

最常见的主键生成方式是数据库自增主键,在创建表时,我们可以为id字段设置AUTO_INCREMENT属性,这样插入数据时,数据库会自动为主键分配一个递增的值,在MyBatis中,我们只需要在mapper.xml文件中定义好对应的insert语句即可。

我们有一个User表,其id字段为自增主键:

CREATE TABLE user (
  id int(11) NOT NULL AUTO_INCREMENT,
  username varchar(255) NOT NULL,
  password varchar(255) NOT NULL,
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

在UserMapper.xml文件中,我们可以定义如下的insert语句:

<insert id="insertUser" parameterType="com.example.entity.User">
    INSERT INTO user (username, password)
    VALUES ({username}, {password})
</insert>

当我们执行insertUser方法时,数据库会自动为主键分配一个递增的值。

2. UUID作为主键

在某些场景下,我们需要使用UUID作为主键,UUID(Universally Unique Identifier)是一种128位的数字标识符,它可以保证在全球范围内的唯一性,在MyBatis中,我们可以使用Java的UUID类来生成UUID,并将其作为主键插入到数据库中。

在User实体类中,我们将id字段的类型修改为String:

public class User {
    private String id;
    private String username;
    private String password;
    // getter和setter方法省略
}

在UserMapper.xml文件中,我们可以定义如下的insert语句:

<insert id="insertUser" parameterType="com.example.entity.User">
    INSERT INTO user (id, username, password)
    VALUES ({id}, {username}, {password})
</insert>

接下来,在对应的Mapper接口中,我们可以添加一个生成UUID的方法:

public interface UserMapper {
    int insertUser(User user);
    String generateUUID();
}

在调用insertUser方法之前,我们先调用generateUUID方法生成一个UUID,并将其赋值给user对象的id字段:

User user = new User();
user.setId(userMapper.generateUUID());
user.setUsername("test");
user.setPassword("123456");
userMapper.insertUser(user);

3. 序列生成器生成主键

除了数据库自增主键和UUID之外,我们还可以使用序列生成器来生成主键,序列生成器是一种特殊的数据库对象,它可以生成一个递增的整数序列,在MyBatis中,我们可以使用数据库自带的序列生成器,或者使用第三方库如HikariCP提供的序列生成器。

以MySQL为例,我们可以创建一个名为user_seq的序列:

CREATE SEQUENCE user_seq INCREMENT BY 1 START WITH 1;

在UserMapper.xml文件中,我们可以定义如下的insert语句:

<insert id="insertUser" parameterType="com.example.entity.User">
    INSERT INTO user (id, username, password)
    VALUES (user_seq.nextval, {username}, {password})
</insert>

4. MyBatis插件生成主键

除了上述方法之外,我们还可以使用MyBatis插件来生成主键,MyBatis插件可以在执行SQL前后对SQL进行拦截和处理,从而实现一些自定义的功能,我们可以编写一个MyBatis插件,用于自动生成主键并替换掉SQL中的占位符。

我们需要实现Interceptor接口:

public class AutoKeyGeneratorInterceptor implements Interceptor {
    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        // 在这里实现自动生成主键的逻辑,并将主键替换掉SQL中的占位符
        return invocation.proceed();
    }
}

在MyBatis配置文件中注册这个插件:

<configuration>
    <!-...其他配置... -->
    <plugins>
        <plugin interceptor="com.example.AutoKeyGeneratorInterceptor"/>
    </plugins>
</configuration>

在对应的Mapper接口中,我们可以将id字段的类型修改为Integer:

0