MyBatisPlus-映射匹配兼容性

简介: MyBatisPlus-映射匹配兼容性

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

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

50a4ed4520864e0cad8e8cfac2efe8cb.png

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

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

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

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

e828cb98a62144039fa5bb0eaed0481e.png

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

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

7be968904e4c45e2aa854858a7e0b165.png

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

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

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

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

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

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


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

5db95aa2cc684b0887cbdc74b528daf7.png

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

fb3859f2efdf42eea114cb0b735d7625.png

名称 @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; 
}
目录
相关文章
|
XML Oracle Java
mybatis反向生成实体类、dao层以及映射文件
mybatis反向生成实体类、dao层以及映射文件
|
1月前
|
SQL Java 数据库连接
MyBatis 的映射关系
MyBatis 核心功能之一是映射关系,支持一对一、一对多和多对多三种 ORM 映射。通过实体类与配置文件结合,开发者可灵活实现数据关联,提升数据库操作效率。
186 4
|
5月前
|
SQL XML Java
菜鸟之路Day35一一Mybatis之XML映射与动态SQL
本文介绍了MyBatis框架中XML映射与动态SQL的使用方法,作者通过实例详细解析了XML映射文件的配置规范,包括namespace、id和resultType的设置。文章还对比了注解与XML映射的优缺点,强调复杂SQL更适合XML方式。在动态SQL部分,重点讲解了`<if>`、`<where>`、`<set>`、`<foreach>`等标签的应用场景,如条件查询、动态更新和批量删除,并通过代码示例展示了其灵活性与实用性。最后,通过`<sql>`和`<include>`实现代码复用,优化维护效率。
443 5
|
7月前
|
SQL XML Java
七、MyBatis自定义映射resultMap
七、MyBatis自定义映射resultMap
191 6
|
7月前
|
Java 数据库连接 mybatis
MyBatis篇-映射关系(1-1 1-n n-n)
本文介绍了MyBatis中四种常见关系映射的配置方法,包括一对一、一对多、多对一和多对多。**一对一**通过`resultMap`实现属性与字段的映射;**一对多**以用户-角色为例,使用`<collection>`标签关联集合数据;**多对一**以作者-博客为例,利用`<association>`实现关联;**多对多**则通过引入第三方类(如UserForDept)分别在User和Dept类中添加集合属性,并配置对应的`<collection>`标签完成映射。这些方法解决了复杂数据关系的处理问题,提升了开发效率。
|
10月前
|
XML Java 数据库连接
Mybatis映射关系
简介:本文介绍了MyBatis框架中四种常见的关系映射方式,包括一对一、一对多、多对一及多对多。一对一通过简单属性映射实现;一对多通过在主对象中添加集合属性并使用`<collection>`标签映射子对象集合;多对一则利用`<association>`标签在主对象中映射单个子对象;多对多需引入第三方类,分别在两个主对象中添加对方的集合属性,并通过`<collection>`标签实现映射。
197 32
|
11月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
466 3
|
Java 数据库连接 mybatis
mybatis映射关系(1-1 1-n n-n)
Mybatis 中的关系映射包括一对一、一对多和多对多。一对一映射可以通过ResultMap定义属性与字段的对应。一对多示例中,User类包含List<Role>,在User的mapper.xml中使用<collection>标签。多对一的情况,如Author与Blog,Blog的ResultMap中使用<association>来映射Author属性。多对多时,如部门与用户,通常需要中间表,并在双方实体中通过<collection>引用中间类,如UserForDept,来维护关系。