MyBatisPlus基本使用

文章目录[隐藏]

导入依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.2.0</version>
</dependency>

编写实体类

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

编写Mapper接口

@Mapper
public interface UserMapper extends BaseMapper<User> {
}

继承自BaseMapper,实现基本的增删改查操作

编写单元测试

@Autowired
UserMapper userMapper;

@Test
void Insert() {
    User user = new User();
    user.setName("周八");
    user.setAge(18);
    user.setEmail("123456@qq.com");
    userMapper.insert(user);
}

注意

数据表结构如下:

id为自增,因此需要在实体类中用

@TableId(type = IdType.AUTO)

来指定主键的生成策略为自增。

若不使用,会出现以下问题:

若id的类型是int而不是bigint,在运行时就会报错:

这就说明在插入时数据就已经那么大了,因此导致id异常,此时加上注解即可,再次运行测试:

id正常(正常地自增了1),但是就是看着不爽,这是因为:

主键是唯一的,绝对不能出现重复,只要曾经出现过,哪怕删掉了也不能用,这是数据库设计问题。

解决方法:

一般来说没有必要保持序号的绝对连续,除非这个序号是直接显示在报表上的,如果是这样,还不如在生成报表的时候再临时生成这个序号。
如果一定要保持这个序号的绝对连续,可以尝试以下方法:

  1. 截断表或删除表再重新导入
  2. 由于自增长列当前值存储在内存中,数据库每次重启之后,会查询当前表中自增列的最大值作为当前值,如
    果表数据被清空之后,数据库重启了,自增列的值将从初始值开始,可以尝试重启数据库。
alter table uer AUTO_INCREMENT 999;

999不能小于表中数据的最大id

alter table tableName auto_increment=select max(id) from tableName ;

不能有=号,alter table tableName AUTO_INCREMENT = 999;  不报错,但不可以

其他

更多使用可参考官方文档:

https://mp.baomidou.com/guide/


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值