【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic

文章目录

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

一、@TableName

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

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

若实体类类型的类名和要操作的表的表名不一致,会出现什么问题?
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第1张图片
(1)通过@TableName解决问题

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

【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第2张图片
(2)通过全局配置解决问题
在开发的过程中,我们经常遇到以上的问题,即实体类所对应的表都有固定的前缀,例如t_tbl_
此时,可以使用MyBatis-Plus提供的全局配置,为实体类所对应的表名设置默认的前缀,那么就
不需要在每个实体类上通过@TableName标识实体类对应的表
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第3张图片

二、@TableId

(1)在实体类中uid属性上通过@TableId将其标识为主键,即可成功执行SQL语句
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第4张图片
(2)@TableIdvalue属性
若实体类中主键对应的属性为id,而表中表示主键的字段为uid,此时若只在属性id上添加注解
@TableId,则抛出异常Unknown column 'id' in 'field list',即MyBatis-Plus仍然会将id作为表的主键操作,而表中表示主键的是字段uid

此时需要通过@TableId注解的value属性,指定表中的主键字段,@TableId("uid")@TableId(value="uid")
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第5张图片
(3)@TableIdtype属性
type属性用来定义主键策略
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第6张图片
也可以在yml文件内配置全局主键策略:
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第7张图片
此时注意,表中id字段已设置为自增,否则配置的自增无法生效
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第8张图片

三、@TableField

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

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

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

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

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

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

【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第9张图片

四、@TableLogic

该注解属于逻辑删除

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

(1)数据库中创建逻辑删除状态列,设置默认值为0
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第10张图片
(2)实体类中添加逻辑删除属性
【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第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

【MybatisPlus 学习】一篇文章带你学习常用注解@TableName 、@TableId 、@TableField 、@TableLogic_第12张图片

你可能感兴趣的:(MybatisPlus,学习笔记,学习,java,开发语言)