文章目录

  • 一、@TableName
  • 二、@TableId
  • 三、@TableField
  • 四、@TableLogic

一、@TableName

经过以上的测试,在使用MyBatis-Plus实现基本的CRUD时,我们并没有指定要操作的表,只是在 Mapper接口继承BaseMapper时,设置了泛型User,而操作的表为user表

由此得出结论,MyBatis-Plus在确定操作的表时,由BaseMapper的泛型决定,即实体类型决定,且默认操作的表名和实体类型的类名一致

若实体类类型的类名和要操作的表的表名不一致,会出现什么问题?

springboot 获取mybatis编译后的sql语句_开发语言

(1)通过@TableName解决问题

@Test
    public void testSelectById(){
        final User user = userMapper.selectById(1L);
        System.out.println(user);
    }

springboot 获取mybatis编译后的sql语句_学习_02

(2)通过全局配置解决问题

在开发的过程中,我们经常遇到以上的问题,即实体类所对应的表都有固定的前缀,例如t_tbl_ 此时,可以使用MyBatis-Plus提供的全局配置,为实体类所对应的表名设置默认的前缀,那么就

不需要在每个实体类上通过@TableName标识实体类对应的表

springboot 获取mybatis编译后的sql语句_学习_03

二、@TableId

(1)在实体类中uid属性上通过@TableId将其标识为主键,即可成功执行SQL语句

springboot 获取mybatis编译后的sql语句_java_04


(2)@TableIdvalue属性

若实体类中主键对应的属性为id,而表中表示主键的字段为uid,此时若只在属性id上添加注解

@TableId,则抛出异常Unknown column 'id' in 'field list',即MyBatis-Plus仍然会将id作为表的主键操作,而表中表示主键的是字段uid此时需要通过@TableId注解的value属性,指定表中的主键字段,@TableId("uid")@TableId(value="uid")

springboot 获取mybatis编译后的sql语句_开发语言_05


(3)@TableIdtype属性

type属性用来定义主键策略

springboot 获取mybatis编译后的sql语句_实体类_06


也可以在yml文件内配置全局主键策略:

springboot 获取mybatis编译后的sql语句_开发语言_07


此时注意,表中id字段已设置为自增,否则配置的自增无法生效

springboot 获取mybatis编译后的sql语句_开发语言_08

三、@TableField

经过以上的测试,我们可以发现,MyBatis-Plus在执行SQL语句时,要保证实体类中的属性名和
表中的字段名一致

如果实体类中的属性名和字段名不一致的情况,会出现什么问题呢?

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

例如实体类属性userName,表中字段user_name 此时MyBatis-Plus会自动将下划线命名风格转化为驼峰命名风格,相当于在MyBatis中配置

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

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

springboot 获取mybatis编译后的sql语句_学习_09

四、@TableLogic

该注解属于逻辑删除

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

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

springboot 获取mybatis编译后的sql语句_学习_10


(2)实体类中添加逻辑删除属性

springboot 获取mybatis编译后的sql语句_字段_11


(3)测试

测试删除功能,真正执行的是修改

UPDATE t_user SET is_deleted=1 WHERE id=? AND is_deleted=0

测试查询功能,被逻辑删除的数据默认不会被查询

SELECT id,username AS name,age,email,is_deleted FROM t_user WHERE is_deleted=0

springboot 获取mybatis编译后的sql语句_开发语言_12