一、表字段与编码属性设计不同步
当表的列名和模型类的属性名发生不一致,就会导致数据封装不到模型对象。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; }