MybatisPlus常用注解

目录

1.@TableName

2.@TableId

(1)解决数据库id和实体类id名称不匹配的问题

(2)决定id生成策略

3.@TableField

4.@TableLogic


1.@TableName

我们在使用MyBatis-Plus实现基本的CRUD时,我们并没有指定要操作的表,只是在 Mapper接口继承BaseMapper时,设置了泛型User,而操作的表为user表 所以MyBatis-Plus在确定操作的表时,由BaseMapper的泛型决定,即实体类型决定,且默认操作的表名和实体类型的类名一致

如果我们的实体类类名和我们要操作的表面不一致会发生什么?

我们把数据库表名字改一下:

改完后运行测试方法:

我们看到数据库的报错说user表不存在,所以MybatisPlus操作的是我们指定的User类

如果遇到这种情况,我们可以用@TableName注解解决

我们在实体类User的上面添加注解@TableName("t_user")

再重新运行刚才的测试方法:

运行就成功了。

@TableName注解可以用来解决实体类和数据库表名称不匹配的问题。

我们也可以通过配置全局来解决这个问题:

把User实体类上面的@TableName注解去掉,随后在yaml配置文件中配置统一前缀

2.@TableId

@TableId主要有两个作用:

(1)解决数据库id和实体类id名称不匹配的问题

(2)决定id生成策略

(1)解决数据库id和实体类id名称不匹配的问题

假如我们实体类的id命名和数据库中的并不一致,我们可以在实体类当中的id声明上一行写上数据库id,假如数据库id名称是uid,实体类里面的id名称是id:

我们直接运行测试方法的话:

此时mybatisplus找不到主键名称

我们在实体类这里加上:

再运行:

问题就解决了

(2)决定id生成策略

@TableName可以携带两个参数,一个是value,解决id匹配的问题,一个是type,决定id的生成策略。

我们比较常用的id生成策略有两种:雪花算法ASSIGN_ID和数据库id自增AUTO

在使用自增的时候要保证数据库当中的自动递增是打开的,否则会报错:

雪花算法:

雪花算法是由Twitter公布的分布式主键生成算法,它能够保证不同表的主键的不重复性,以及相同表的 主键的有序性。

①核心思想:

长度共64bit(一个long型)。

首先是一个符号位, 1bit标识,由于long基本类型在Java中是带符号的,最高位是符号位,正数是0,负数是1,所以id一般是正数,最高位是0。

41bit时间截(毫秒级),存储的是时间截的差值(当前时间截 - 开始时间截),结果约等于69.73年。

10bit作为机器的ID( 5个bit是数据中心, 5个bit的机器ID,可以部署在1024个节点)。

12bit作为毫秒内的流水号(意味着每个节点在每毫秒可以产生 4096 个 ID)。

②优点:整体上按照时间自增排序,并且整个分布式系统内不会产生ID碰撞,并且效率较高。

3.@TableField

经过以上的测试,我们可以发现, MyBatis-Plus在执行SQL语句时,要保证实体类中的属性名和 表中的字段名一致。
如果实体类中的属性名和字段名不一致的情况,会出现什么问题呢?

(1)若实体类中的属性使用的是驼峰命名风格,而表中的字段使用的是下划线命名风格

例如实体类属性userName,表中字段user_name

此时MyBatis-Plus会自动将下划线命名风格转化为驼峰命名风格

(2)若实体类中的属性和表中的字段不满足情况(1)

例如实体类属性name ,表中字段username

此时需要在实体类属性上使用@TableField("username")设置属性所对应的字段名

第二类情况和上面的id和table名字是一样的,就不再赘述。

4.@TableLogic

物理删除:真实删除,将对应数据从数据库中删除,之后查询不到此条被删除的数据
逻辑删除:假删除,将对应数据中代表是否被删除字段的状态修改为"被删除状态",之后在数据库
中仍旧能看到此条数据记录
使用场景:可以进行数据恢复
实现逻辑删除:

数据库中创建逻辑删除状态列,设置默认值为0

然后在实体类中添加逻辑删除

最后测试:

我们可以看到它实际上执行的是update方法,把id为23的记录的is_deleted字段更新成了1

相关推荐
周末也要写八哥几秒前
线程的生命周期之线程睡眠
java·开发语言·jvm
炸薯条!6 分钟前
二叉树的链式表示(2)
java·数据结构·算法
右耳朵猫AI9 分钟前
Python周刊2026W22 | Django 6.1 Alpha 1发布、Nuitka 4.1发布、PEP 831终稿、PEP 808已接受
开发语言·python·django
半个烧饼不加肉11 分钟前
JS 底层探究-- 普通函数和构造函数
开发语言·javascript·原型模式
徐寿春18 分钟前
什么是数据倾斜
java·guava
小白不白11120 分钟前
C# WinForm 与 VP 二次开发
开发语言·c#
李白的天不白26 分钟前
一个服务器可以搭建多个网站
java·tomcat
●VON26 分钟前
AtomGit Flutter鸿蒙客户端:共享组件
java·flutter·华为·harmonyos·鸿蒙
程序猿乐锅27 分钟前
【JAVASE | 第十七篇】Java 网络通信
java·开发语言
执于代码28 分钟前
Java交互打印的问题
java