导入依赖
<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),但是就是看着不爽,这是因为:主键是唯一的,绝对不能出现重复,只要曾经出现过,哪怕删掉了也不能用,这是数据库设计问题。
解决方法:
一般来说没有必要保持序号的绝对连续,除非这个序号是直接显示在报表上的,如果是这样,还不如在生成报表的时候再临时生成这个序号。
如果一定要保持这个序号的绝对连续,可以尝试以下方法:
- 截断表或删除表再重新导入
- 由于自增长列当前值存储在内存中,数据库每次重启之后,会查询当前表中自增列的最大值作为当前值,如
果表数据被清空之后,数据库重启了,自增列的值将从初始值开始,可以尝试重启数据库。
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/