MyBatisPlus(十四)主键策略

说明

MyBatis Plus 集成了多种主键策略,帮助用户快速生成主键。

  1. 雪花算法ID(默认策略)(推荐)
  2. UUID
  3. 自增ID
  4. 用户输入ID(必须用户每次插入数据时,手动传入ID)

雪花算法ID:IdType.ASSIGN_ID(推荐)

默认情况,全局使用的,就是雪花算法ID。也就是说,id字段在没有指定任何主键策略时,插入数据就是使用的雪花算法生成的ID。

注解

如果全局使用雪花算法ID,这个注解可以不加。

java 复制代码
@TableId(type = IdType.ASSIGN_ID)

代码

java 复制代码
package com.example.web.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;

@Data
public class User {
    @TableId(type = IdType.ASSIGN_ID)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}
java 复制代码
    @Test
    public void insert() {
        User user = new User();
        user.setName("赵一");
        user.setAge(26);
        user.setEmail("[email protected]");

        mapper.insert(user);
    }

效果

UUID:IdType.ASSIGN_UUID

注解

java 复制代码
@TableId(type = IdType.ASSIGN_UUID)

代码

java 复制代码
package com.example.web.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;

@Data
public class User {
    @TableId(type = IdType.ASSIGN_UUID)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}
java 复制代码
    @Test
    public void insert() {
        User user = new User();
        user.setName("赵一");
        user.setAge(26);
        user.setEmail("[email protected]");

        mapper.insert(user);
    }

效果


自增ID:IdType.AUTO

该类型请确保数据库设置了 ID自增,否则无效(会报错)。

报错信息查看文章最后的《报错示例》

注解

java 复制代码
@TableId(type = IdType.AUTO)

代码与测试

java 复制代码
package com.example.web.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;

@Data
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}
java 复制代码
    @Test
    public void insert() {
        User user = new User();
        user.setName("赵一");
        user.setAge(26);
        user.setEmail("[email protected]");

        mapper.insert(user);
    }

效果


用户输入ID:IdType.INPUT

注解

java 复制代码
@TableId(type = IdType.INPUT)

代码

java 复制代码
package com.example.web.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;

@Data
public class User {
    @TableId(type = IdType.INPUT)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}
java 复制代码
    @Test
    public void insert() {
        User user = new User();
        user.setId(9L);
        user.setName("赵一");
        user.setAge(26);
        user.setEmail("[email protected]");

        mapper.insert(user);
    }

效果

指定id之后,插入数据成功

未指定ID报错

如果不指定id,也就是 setId() 方法没调用,会报错:

Column 'id' cannot be null

补充:报错示例(IdType.AUTO)

当 MySQL 数据库中的表,ID并没有自增,但是代码中的id是自增,此时新增一条数据,会报错。

实体类

java 复制代码
package com.example.web.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import lombok.Data;

@Data
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String name;
    private Integer age;
    private String email;
}

插入数据方法

java 复制代码
    @Test
    public void insert() {
        User user = new User();
        user.setName("赵一");
        user.setAge(26);
        user.setEmail("[email protected]");

        mapper.insert(user);
    }

报错信息

相关推荐
岁岁岁平安1 个月前
基于SpringBoot3实现MyBatis-Plus(SSMP)整合快速入门CURD(增删改查)
java·spring boot·spring·java-ee·mvc·mybatis·mybatis-plus
依旧很淡定1 个月前
14-SpringBoot3入门-MyBatis-Plus之CRUD
mybatis-plus·crud
我要学编程(ಥ_ಥ)2 个月前
初始JavaEE篇 —— Mybatis-plus 操作数据库
java·java-ee·mybatis·mybatis-plus
救救孩子把2 个月前
MyBatis-Flex、MyBatis-Plus 与 Fluent-Mybatis 的比较分析
java·mybatis·mybatis-plus·mybatis-flex·fluent-mybatis
码熔burning2 个月前
MyBatis-Plus 自动填充:优雅实现创建/更新时间自动更新!
java·mybatis·springboot·mybatis-plus
奔跑吧邓邓子2 个月前
【商城实战(25)】解锁UniApp移动端适配秘籍,打造完美商城体验
uni-app·springboot·mybatis-plus·移动端适配·商城实战
自在如风。2 个月前
MyBatis-Plus 使用技巧
java·mybatis·mybatis-plus
drebander2 个月前
MyBatis-Plus 逻辑删除实现
tomcat·mybatis·mybatis-plus
GGBondlctrl3 个月前
【Mybatis】如何简单使用mybatis-plus,以及MybatisGenerator自动生成或者实现SQL语句
java·sql·mybatis·mybatis-plus·数据库generator·自动生成sql
drebander3 个月前
MyBatis-Plus 对比传统 MyBatis 的优势
mybatis-plus