MyBatisPlus深入探究映射匹配的兼容性

作者:十八岁讨厌编程 时间:2023-01-08 08:57:26 

映射匹配兼容性

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

MyBatisPlus深入探究映射匹配的兼容性

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

那么问题就来了:

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

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

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

MyBatisPlus深入探究映射匹配的兼容性

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

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

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

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

MyBatisPlus深入探究映射匹配的兼容性

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

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

MyBatisPlus深入探究映射匹配的兼容性

知识点@TableField

名称@TableField
类型属性注解
位置模型类属性定义上方
作用设置当前属性对应的数据库表中的字段关系
相关属性value(默认):设置数据库表字段名称
exist:设置属性在数据库表字段中是否存在,默认为true,此属性不能与value合并使用
select:设置属性是否参与查询,此属性与select()映射配置不冲突
  • 问题4:表名与编码开发设计不同步

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

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

MyBatisPlus深入探究映射匹配的兼容性

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

MyBatisPlus深入探究映射匹配的兼容性

知识点@TableName

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

代码演示

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

步骤1:修改数据库表user为tbl_user

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

MyBatisPlus深入探究映射匹配的兼容性

步骤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默认情况下会使用模型类的属性名当做表的列名使用

MyBatisPlus深入探究映射匹配的兼容性

步骤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不存在

MyBatisPlus深入探究映射匹配的兼容性

步骤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;
}

来源:https://blog.csdn.net/zyb18507175502/article/details/126044172

标签:MyBatis,Plus,映射匹配,兼容性
0
投稿

猜你喜欢

  • Java Stax解析XML示例

    2022-04-07 13:42:15
  • Java ArrayList与LinkedList使用方法详解

    2023-08-12 08:23:46
  • Java SSM配置文件案例详解

    2022-10-14 09:43:19
  • 分析Android Choreographer源码

    2022-09-04 07:25:12
  • Android 刘海屏适配总结(推荐)

    2022-03-23 23:26:55
  • Android进程运行中权限被收回导致关闭的问题解决

    2023-11-21 16:56:45
  • Java反射机制基础详解

    2023-07-17 04:36:29
  • Spring Bean的线程安全问题

    2023-06-07 17:15:36
  • 在spring中手写全局异常拦 截器

    2023-11-09 01:25:42
  • c# 通过WinAPI播放PCM声音

    2021-10-22 12:35:18
  • Android LayoutInflater.inflate源码分析

    2022-06-06 17:02:05
  • SpringBoot 实现自定义的 @ConditionalOnXXX 注解示例详解

    2023-04-04 03:37:18
  • C++ 继承,虚继承(内存结构)详解

    2023-09-05 21:28:01
  • 说说在Spring中如何引用外部属性文件的方法

    2023-09-18 21:47:25
  • 详解Java接口签名(Signature)实现方案

    2022-02-05 09:28:57
  • SpringBoot过滤器与拦截 器深入分析实现方法

    2023-11-28 23:04:15
  • Java ThreadLocal的使用详解

    2023-11-29 04:48:43
  • 详解Spring如何解析占位符

    2023-11-27 12:44:46
  • java项目中的绝对路径和相对路径用法说明

    2023-11-27 22:08:44
  • java Wrapper类基本用法详解

    2022-12-20 18:20:05
  • asp之家 软件编程 m.aspxhome.com