广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis-Plus映射匹配兼容性的问题解决
  • 445
分享到

Mybatis-Plus映射匹配兼容性的问题解决

Mybatis-Plus映射匹配兼容性Mybatis-Plus映射匹配 2023-01-11 12:01:32 445人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录问题一:表字段与编码属性设计不同步问题二:编码中添加了数据库中未定义的属性问题三:采用默认查询开放了更多的字段查看权限问题四:表名与编码开发设计不同步从表中查询出数据,并将数据封

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

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

这样可能会产生以下问题:

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

当表的列名和模型类的属性名发生不一致,就会导致数据封装不到模型对象
这个时候就需要其中一方做出修改,那如果前提是两边都不能改又该如何解决?
MP提供了一个注解@TableField,使用该注解可以实现模型类属性名和表的列名之间的映射关系

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

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

@TableField 注解它有一个属性叫exist

设置该字段是否在数据库表中存在,如果设置为false则不存在,生成sql语句查询的时候,就不会再查询该字段了

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

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

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

相关属性:

  • value(默认):设置数据库表字段名称
  • exist:设置属性在数据库表字段中是否存在,默认为true,此属性不能与value合并使用
  • select:设置属性是否参与查询,此属性与select()映射配置不冲突

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

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

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

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

到此这篇关于mybatis-Plus 映射匹配兼容性的问题解决的文章就介绍到这了,更多相关Mybatis-Plus 映射匹配兼容性内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Mybatis-Plus映射匹配兼容性的问题解决

本文链接: https://www.lsjlt.com/news/177412.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mybatis-Plus映射匹配兼容性的问题解决
    目录问题一:表字段与编码属性设计不同步问题二:编码中添加了数据库中未定义的属性问题三:采用默认查询开放了更多的字段查看权限问题四:表名与编码开发设计不同步从表中查询出数据,并将数据封...
    99+
    2023-01-11
    Mybatis-Plus 映射匹配兼容性 Mybatis-Plus 映射匹配
  • JPA与mybatis-plus不兼容问题的解决
    引入mybatis-plus后,在spring-boot启动时,JPA会使用CCJSqlParser对SQL进行分析处理,由于@Query中的Native-SQL语法并非完全的sql...
    99+
    2023-02-24
    JPA与mybatis-plus不兼容 Mybatis Plus JPA 冲突
  • 解决mybatis-plus自动配置的mapper.xml与java接口映射问题
    目录mybatis-plus自动配置mapper.xml与java接口映射其中核心功能就是下面这个方法mybatis-plus3 配置mapper和xml映射关系原因就是mapper...
    99+
    2022-11-12
  • MyBatis高级映射ResultMap解决属性问题
    目录ResultMap结果映射解决复杂属性多对一关系处理按照查询嵌套按照结果嵌套一对多关系处理按照结果嵌套按照查询嵌套ResultMap结果映射解决复杂属性 之前我们提到了用resu...
    99+
    2023-02-20
    MyBatis高级映射ResultMap MyBatis ResultMap处理属性
  • MyBatis的SUM映射问题及解决
    目录SUM映射问题原因解决方式sum 返回映射问题(sum报表统计接口返回)MyBatis sum 返回值映射SUM映射问题 当我们根据类别进行统计,返回的数据类型为HashMap&...
    99+
    2022-11-13
  • Mybatis plus:兼容多数据库时解决databaseId为空问题
            一开始用调用xml语句,具体报错如下:         用调用xml的SQL报错 Invalid bound statement (not found),离谱的是调用部分数据源pg数据源正常,调用mysql数据源就包这个错...
    99+
    2023-09-13
    mybatis mysql databaseId
  • MyBatis的SUM映射问题怎么解决
    本文小编为大家详细介绍“MyBatis的SUM映射问题怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“MyBatis的SUM映射问题怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。SUM映射问题当我...
    99+
    2023-06-29
  • 怎么使用MyBatis高级映射ResultMap解决属性问题
    本篇内容介绍了“怎么使用MyBatis高级映射ResultMap解决属性问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!ResultMap...
    99+
    2023-07-05
  • 解决Mybatis映射文件mapper.xml中的注释问题
    目录Mybatis映射文件mapper.xml的注释问题报错信息解决办法mapper.xml文件中的注释注释方式‘无效的列索引’bug和解决小结一下Mybat...
    99+
    2022-11-12
  • 如何解决mybatis-plus实体类中出现非数据库映射字段的问题
    本篇内容主要讲解“如何解决mybatis-plus实体类中出现非数据库映射字段”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何解决mybatis-plus实体类中出现非数据库映射字段”吧!在使...
    99+
    2023-06-07
  • 如何解决cssdisplaynlineblock的兼容性问题
    今天就跟大家聊聊有关如何解决cssdisplaynlineblock的兼容性问题,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 ...
    99+
    2022-10-19
  • mybatis 解决从列名到属性名的自动映射失败问题
    问题背景 从数据库中取出数据映射到实体类时,实体类中只有部分属性映射成功,其余属性值皆为null。 问题描述 如下图AreaDao.xml文件中描述了queryArea()方法从数据...
    99+
    2022-11-12
  • JS如何解决position:sticky的兼容性问题
    这篇文章主要介绍JS如何解决position:sticky的兼容性问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在项目中有用到sticky的布局,可是由于兼容性问题,在安卓端没有...
    99+
    2022-10-19
  • mybatis如何解决从列名到属性名的自动映射失败的问题
    本篇内容介绍了“mybatis如何解决从列名到属性名的自动映射失败的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题背景从数据库中取出...
    99+
    2023-06-20
  • JS脚本兼容性问题的解决方法
    这篇文章给大家介绍JS脚本兼容性问题的解决方法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。这里和大家分享一下解决JS脚本兼容的几个小技巧,关于JS脚本兼...
    99+
    2022-10-19
  • 怎么解决mybatis映射和实际类型不一致的问题
    本篇内容主要讲解“怎么解决mybatis映射和实际类型不一致的问题”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么解决mybatis映射和实际类型不一致的问题”吧!mybatis映射和实际类型...
    99+
    2023-06-21
  • css min-height属性的兼容问题怎么解决
    CSS min-height属性的兼容问题可以通过以下方法解决:1. 使用浏览器前缀:在不同浏览器中添加对应的浏览器前缀,如-web...
    99+
    2023-10-12
    css
  • 如何解决360对jquery的html()兼容性问题
    这篇文章主要为大家展示了“如何解决360对jquery的html()兼容性问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何解决360对jquery的htm...
    99+
    2022-10-19
  • 如何解决axios在ie下的兼容性问题
    小编给大家分享一下如何解决axios在ie下的兼容性问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!首先说下axios虽说是支...
    99+
    2022-10-19
  • Windows与Java的兼容性问题该如何解决?
    随着Java技术的广泛应用,Windows系统与Java的兼容性问题也逐渐浮出水面。这些问题可能会导致应用程序无法正常运行,给用户带来不必要的麻烦。本文将介绍Windows与Java兼容性问题的原因,并提供一些解决方案。 原因分析: Wi...
    99+
    2023-07-29
    linux leetcode windows
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作