• MybatisPlus 3 DQL 编程控制 3.4 映射匹配兼容性


    MybatisPlus

    【黑马程序员2022新版SSM框架教程_Spring+SpringMVC+Maven高级+SpringBoot+MyBatisPlus企业实用开发技术】

    3 DQL 编程控制

    3.4 映射匹配兼容性

    【问题引入】

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

    在这里插入图片描述

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

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

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

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

    在这里插入图片描述

    这样也可以成功封装。

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

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

    在这里插入图片描述

    错误信息为: Unknown column ‘多出来的字段名称’ in ‘field list’

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

    在这里插入图片描述

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

    查询表中所有的列的数据,就可能把一些敏感数据【比如密码】查询到返回给前端,

    这个时候就需要限制哪些字段默认不要进行查询。解决方案是@TableField注解的一个属性叫select,该属性设置默认是否需要查询该字段的值,true(默认值)表示默认查询该字段,false表示默认不查询该字段。

    在这里插入图片描述

    【知识点1:@TableField】

    在这里插入图片描述

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

    该问题主要是表的名称和模型类的名称不一致,导致查询失败,

    在这里插入图片描述

    这个时候通常会报如下错误信息

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

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

    在这里插入图片描述

    【知识点2:@TableName】

    在这里插入图片描述

    注意:MP默认情况下会使用模型类的类名首字母小写当表名使用

  • 相关阅读:
    No.10软件设计
    网络原理必知会
    Springboot集成redis--不同环境切换
    选择排序--java(详解)
    数据结构01 栈及其相关问题讲解【C++实现】
    Ubuntu24.04下安装docker,并pull ubuntu22.04,然后编译安装vpp
    C#,二分图(Bipartite Graph)最佳二分匹配(Maximum Bipartite Matching)算法与源程序
    Linux:云服务器搭建ftp
    【版本发布公告】HMS Core 6.6.0来啦
    Thread类的常用方法
  • 原文地址:https://blog.csdn.net/weixin_44226181/article/details/127419754