• Java开发学习(四十五)----MyBatisPlus查询语句之映射匹配兼容性


    1、映射匹配兼容性

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

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

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

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

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

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

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

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

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

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

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

    知识点1:@TableField

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

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

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

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

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

    知识点2:@TableName

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

     

     



    如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,但是未经作者本人同意,转载文章之后必须在文章页面明显位置给出作者和原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    P4774 [NOI2018] 屠龙勇士
    致谢每一位ChunJun Contributor!这里有一份礼物等你领取!
    MS Access 教程之 如何在不覆盖标题字段的情况下将 Excel 数据导入 MS Access 现有表?
    【技术美术图形部分】图形渲染管线3.0-光栅化和像素处理阶段
    Qt超时机制设计
    Lesson11——NumPy 位运算
    SD卡格式化怎么恢复?
    商城项目14_商品新增vo抽取、修改vo、新增逻辑、代码的具体落地、SPU检测、SKU检测、流程图
    【HDU No. 3567】八数码 II Eight II
    【Python微信机器人】第六七篇: 封装32位和64位Python hook框架实战打印微信日志
  • 原文地址:https://www.cnblogs.com/xiaoyh/p/16468199.html