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

相关推荐
稚辉君.MCA_P8_Java42 分钟前
Gemini永久会员 归并排序(Merge Sort) 基于分治思想(Divide and Conquer)的高效排序算法
java·linux·算法·spring·排序算法
q***188442 分钟前
Spring Boot中的404错误:原因、影响及处理策略
java·spring boot·后端
你的冰西瓜1 小时前
C++20 新特性详解:相较于 C++17 的主要改进
开发语言·c++·stl·c++20
汤姆Tom1 小时前
前端转战后端:JavaScript 与 Java 对照学习指南 (第一篇 - 深度进阶版)
java·javascript
济宁雪人1 小时前
Java安全基础——JNI安全基础
java·开发语言
q***96581 小时前
Java进阶-在Ubuntu上部署SpringBoot应用
java·spring boot·ubuntu
lsx2024061 小时前
Django 视图详解
开发语言
h***06651 小时前
【JSqlParser】Java使用JSqlParser解析SQL语句总结
java·开发语言·sql
代码or搬砖2 小时前
Java Lambda 表达式全面详解
java·开发语言·python