MyBatisPlus-映射匹配兼容性

本文介绍了在使用 MyBatis Plus(MP)时遇到的四个常见问题:表字段与编码属性设计不同步、编码中添加了数据库中未定义的属性、默认查询权限设置以及表名与编码开发设计不同步。针对这些问题,提供了@TableField 和 @TableName 注解的详细使用方法,包括设置字段映射、是否存在以及查询时的默认选择,以解决数据同步和安全性问题。
摘要由CSDN通过智能技术生成

目录

一、表字段与编码属性设计不同步

二、编码中添加了数据库中未定义的属性

三、采用默认查询开放了更多的字段查看权限

四、表名与编码开发设计不同步

五、代码演示


一、表字段与编码属性设计不同步

当表的列名和模型类的属性名发生不一致,就会导致数据封装不到模型对象。MP提供了一个注解@TableField,使用该注解可以实现属性名和列名之间的映射关系。

二、编码中添加了数据库中未定义的属性

当模型中多了一个数据表中不存在的字段,会导致生成的sql语句在select的时候查询了数据库不存在的字段,程序就会报错,报错信息为:

Unknown column '多出来的字段名称' in 'field list'

具体解决方案可以用到@TableField注解,它有一个属性叫exist,设置该字段是否在数据库表中存在,如果设置为false则不存在,生成sql语句查询的时候,就不会查询该字段。

三、采用默认查询开放了更多的字段查看权限

查询表中所有列的数据,就可能把一些敏感数据查询返回给前端,这个时候我们就需要限制哪些字段默认不要查询。解决方案是@TableField注解的一个属性叫select,该属性设置默认是否需要查询该字段的值,true(默认值)表示默认查询该字段,false表示默认不查询该字段

名称@TableField
类型属性注解
位置模型类属性定义上方
作用设置当前属性对应的数据表中的字段关系
相关属性

value(默认):设置数据表字段名称

exist:设置属性在数据库表字段中是否存在,默认为true,此属性不能与value合并使用

select:设置属性是否参与查询,此属性与select()映射配置不冲突

四、表名与编码开发设计不同步

该问题主要是表的名称和模型类的名称不一致,导致查询失败,这个时候,通常会报如下错误信息

Table 'databaseName.tableNaem' doesn't exist,意思是数据库中的表不存在

解决方案是使用MP提供的另一个注解@TableName来设置表与模型之间的对应关系

名称@TableName
类型类注解
位置模型类定义上方
作用设置当前对应于数据库表关系
相关属性value(默认):设置数据库表名称

五、代码演示

1、修改数据库表user为table_user

直接查询会报错,原因是MP默认下会使用模型类的类名首字母小写当表名使用

2、模型类添加@TableName注解

@Data 
@TableName("tbl_user") 
    public class User { 
    private Long id; 
    private String name; 
    private String password; 
    private Integer age; 
    private String tel; 
}

3、将字段password修改为pwd

直接查询会报错,原因是MP默认情况下会使用模型类的属性名当做表的列名使用

4、使用@TableField映射关系

@Data 
@TableName("tbl_user") 
public class User { 
    private Long id; 
    private String name; 
    @TableField(value="pwd") 
    private String password; 
    private Integer age; 
    private String tel; 
}

5、添加一个数据表不存在的字段

直接查询会报错,原因是MP默认情况下会查询模型类的所有属性对应的数据表的列,而online不存在

6、使用@TableField排除字段

@Data 
@TableName("tbl_user") 
    public class User { 
    private Long id; 
    private String name; 
    @TableField(value="pwd") 
    private String password; 
    private Integer age; 
    private String tel; 
    @TableField(exist=false) 
    private Integer online; 
}

7、查询时将pwd隐藏

@Data 
@TableName("tbl_user") 
    public class User { 
    private Long id; 
    private String name; 
    @TableField(value="pwd",select=false) 
    private String password; 
    private Integer age; 
    private String tel; 
    @TableField(exist=false) 
    private Integer online; 
}
  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

夏志121

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值