写点什么

[MyBatisPlus] 映射匹配兼容性

作者:fake smile by
  • 2022 年 9 月 14 日
    黑龙江
  • 本文字数:1548 字

    阅读完需:约 5 分钟

映射匹配兼容性

前面我们已经能从表中查询出数据,并将数据封装到模型类中,这整个过程涉及到一张表和一个模型类:



之所以数据能够成功的从表中获取并封装到模型对象中,原因是表的字段列名和模型类的属性名一样


那么问题就来了:

问题 1:表字段与编码属性设计不同步

当表的列名和模型类的属性名发生不一致,就会导致数据封装不到模型对象,这个时候就需要其中一方做出修改,那如果前提是两边都不能改又该如何解决?


MP 给我们提供了一个注解@TableField,使用该注解可以实现模型类属性名和表的列名之间的映射关系


问题 2:编码中添加了数据库中未定义的属性

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


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


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


问题 3:采用默认查询开放了更多的字段查看权限

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


知识点:@TableField

问题 4:表名与编码开发设计不同步

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


==Table 'databaseName.tableNaem' doesn't exist==,翻译过来就是数据库中的表不存在。



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


知识点:@TableName

代码演示

接下来我们使用案例的方式把刚才的知识演示下:


步骤 1:修改数据库表 user 为 tbl_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:添加一个数据库表不存在的字段


@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;    private Integer online;}
复制代码


直接查询会报错,原因是 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;}
复制代码


发布于: 刚刚阅读数: 5
用户头像

fake smile by

关注

还未添加个人签名 2022.07.31 加入

还未添加个人简介

评论

发布
暂无评论
[MyBatisPlus]映射匹配兼容性_Java_fake smile by_InfoQ写作社区