使用MyBatisPlus让数据库和实体类字段自动映射

文章目录

  • 使用MyBatisPlus让数据库和实体类字段自动映射
    • 需求场景
    • 假如没有映射
    • 把映射放到sql语句中
    • 使用MyBatisPlus提供的注解简化映射

使用MyBatisPlus让数据库和实体类字段自动映射

需求场景

数据库表中的字段名字,与实体类中的属性名字不一致,我们想要让二者映射起来的时候,该怎么操作?比如数据库表中的字段名字如下图:
在这里插入图片描述
而User实体类中的属性名字如下图:
在这里插入图片描述
可以发现名字和年龄这两个字段是不一样的。那么这个时候如果我们想要映射,怎样可以正确的映射呢?

假如没有映射

假如没有映射,看下我们的sql语句,如下图:
在这里插入图片描述
看下我们的数据库表信息,如下图:
在这里插入图片描述
那么我们查询的结果是什么样的呢?如下图:
在这里插入图片描述
可以发现,我们的查询结果中name和age都是null。这也很容易理解,因为数据库表字段和实体类字段没有正确的映射嘛,所以查询结果肯定是空的。

把映射放到sql语句中

因此我们第一种解决方式是把映射写到mapper.xml文件的sql语句中,如下图:
在这里插入图片描述
只把名字不同的映射起来就行了,名字相同的address是不用写的。

最后看下查询结果,如下图:
在这里插入图片描述
可以发现我们查询结果中的name和age都有值了。

使用MyBatisPlus提供的注解简化映射

但是上面的映射有什么问题呢?就是实现起来过于复杂,要写的东西太多了,因此我们后续又出现了MyBatisPlus提供的映射方式,就是我们可以直接通过注解映射。直接把注解写在User实体类上就可以了,如下图:
在这里插入图片描述
本来以为这样写的话应该可以完成自动映射,但是测试的好像还是不行,结果如下图:
在这里插入图片描述
并没有完成自动映射。

目前还没有找到原因,不过后面先按照ResultMap映射把还是。

那既然不能映射的话,@TableField注解是干什么用的呢?原来是我搞错了,@TableField注解不是查询时映射的,而是插入时映射的,就是假如我现在使用MyBatisPlus往数据库user表里面插入一条数据,User实体的属性是name和age,而数据库表的属性是user_name和user_age,那么这样就插入不进去了,就会出现异常了,如下图:
在这里插入图片描述
因为解析的时候是直接把User实体的name属性当做了插入语句的列名,而实际上我们需要的是user_name,因此这里就会出现异常了。而当我们使用@TableField标记数据库表和属性字段的映射的时候,这个错误就会消失了,如下图:
在这里插入图片描述
错误消失如下图:
在这里插入图片描述
看一下数据库中的插入结果,如下图:
在这里插入图片描述

因此@TableField注解主要是用于插入映射的,而不是查询映射。

注意我们这里使用的插入是MyBatisPlus中自动引入的插入方法insert。那我就突然想到,会不会当我们使用MyBatisPlus自带的查询方法的时候,我们使用@TableField注解的查询也会自动映射呢?

使用MyBatisPlus自带的原生方法,如下图:
在这里插入图片描述
看下查询结果,如下图:
在这里插入图片描述
发现确实是可以映射的。

因此我就得出一个结论,只有使用的是MyBatisPlus自带的数据库的操作方法的时候,@TableField注解映射才有效果,否则的话是没有效果的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/352849.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】进程间通信2——命名管道

1. 命名管道(FIFO) 1.1. 基本概念 简单,给匿名管道起个名字就变成了命名管道 那么如何给 匿名管道 起名字呢? 结合文件系统,给匿名管道这个纯纯的内存文件分配 inode,将文件名与之构建联系,关键点在于不给它分配 D…

618数码好物清单,这些好物你不容错过

每次的618大促中,有各类数码产品纷纷亮相,让人眼花缭乱,而且打折的力度都很高,那么在这个充满诱惑的购物季里,哪些电子数码好物值得你入手呢?今天,我就一起给题主盘点那些实用至上、绝对不吃灰的…

RT-Thread-Nano使能动态内存Heap后,程序无法运行

RT-Thread-Nano移植 1. 动态内存堆1.1 问题1.2 解决 3. 问题根源 1. 动态内存堆 1.1 问题 按照官方文档:在 RT-Thread Studio 上使用 RT-Thread Nano,新建nano工程后,可以正常运行。 但是开启内存管理后,系统无法正常启动&…

Docker高级篇之轻量化可视化工具Portainer

文章目录 1. 简介2. Portainer安装 1. 简介 Portianer是一款轻量级的应用,它提供了图形化界面,用于方便管理Docker环境,包括单机环境和集成环境。 2. Portainer安装 官网:https://www.portainer.io 这里我们使用docker命令安装&…

三分钟了解链动3+1模式

在电商领域的营销策略中,链动31模式以其独特的魅力和优势,吸引了众多商家的目光。下面,我们将对这一模式进行深度剖析,并探讨其相较于链动21模式的优势所在。 一、身份设置与奖励机制 链动31模式在身份设置上分为三种&#xff1…

C#观察者模式应用

目录 一、什么是观察者模式 二、C#中观察者模式的实现 三、两种实现的用法 1、事件与委托 2、IObserver和IObservable 四、参考文献 一、什么是观察者模式 观察者(Observer)模式的定义:指多个对象间存在一对多的依赖关系,当…

C++: shared_ptr是线程安全的吗

导读 C面试中有时会有这样一个问题,shared_ptr是线程安全的吗?对此问题,我们需要从三个并发场景进行考虑,拷贝shared_ptr的安全性、对shared_ptr赋值的安全性和读写shared_ptr指向内存区域的安全性。 对于以上问题,首…

python flask配置数据库并进行orm操作 flask_sqlalchemy

🌈所属专栏:【Flask】✨作者主页: Mr.Zwq✔️个人简介:一个正在努力学技术的Python领域创作者,擅长爬虫,逆向,全栈方向,专注基础和实战分享,欢迎咨询! 您的点…

Java——IO流(一)-(4/8):前置知识-字符集、UTF-8、GBK、ASCII、乱码问题、编码和解码等

目录 常见字符集介绍 标准ASCII字符集 GBK(汉字内码扩展规范,国标) Unicode字符集(统一码,万国码) 小结 字符集的编码、解码操作 方法 实例演示 常见字符集介绍 标准ASCII字符集 ASCll(American St…

YOLOv10改进 | 注意力篇 | YOLOv10改进CA注意力机制

1.CA介绍 摘要:最近关于移动网络设计的研究已经证明了通道注意力(例如,挤压和激励注意力)对于提升模型性能的显着有效性,但它们通常忽略了位置信息,而位置信息对于生成空间选择性注意力图很重要。 在本文中,我们通过将位置信息嵌入到通道注意力中,提出了一种新颖的移动…

伊拉克目的港清关严控,所有管控范围内的产品务必申请COC证书

伊拉克目的港清关严控,所有管控范围内的产品务必申请COC证书,COC/COI 伊拉克使馆认证,欢迎随时咨询小詹 近期,伊拉克海关扩大了进口产品管控品类,从产品的12大类700多种商品拓宽到800多种商品, 伊拉克海关…

Nature发文介绍使用ChatGPT帮助学术写作的三种方式

文章链接:https://www.nature.com/articles/d41586-024-01042-3 一、介绍 这篇文章是由Dritjon Gruda撰写的,讨论了生成性人工智能(AI)在学术写作、编辑和同行评审中的三种应用方式。Gruda认为,尽管学术界对聊天机器…

Ubuntu-24.04-live-server-amd64安装界面中文版

系列文章目录 Ubuntu安装qemu-guest-agent Ubuntu-24.04-live-server-amd64启用ssh Ubuntu乌班图安装VIM文本编辑器工具 文章目录 系列文章目录前言一、准备工作二、开始安装三、测试效果总结 前言 Centos结束,转战Ubuntu。我之所以写这篇文章,是因为我…

shell函数

shell函数 定义:将命令序列按照格式写在一起。格式指的是函数的固定格式。两种格式。 作用:方便重复使用。函数库,集中在一起,随时可以传参调用。大的工程分割成若干个小的功能模块,提高代码的可读性。 函数的格式&…

小规模自建 Elasticsearch 的部署及优化

本文将详细介绍如何在 CentOS 7 操作系统上部署并优化 Elasticsearch 5.3.0,以承载千万级后端服务的数据采集。要使用Elasticsearch至少需要三台独立的服务器,本文所用服务器配置为4核8G的ECS云服务器,其中一台作为 master + data 节点、一台作为 client + data 节点、最后一…

闲鱼平台与宝藏详情API接口

一、闲鱼平台简介 闲鱼,是我国知名二手交易平台,成立于2015年,隶属于阿里巴巴集团。联讯数据用户可以在闲鱼上买卖二手商品,实现闲置物品的流通与再利用。随着我国互联网经济的快速发展,闲鱼平台用户规模不断扩大&…

重磅新闻!狂揽120台订单!大运重卡唐山销服一体运营店盛大开业

2024年6月13日,唐山市迎来了一件令人振奋的商用车行业盛事——大运重卡经销商唐山滦都汽贸暨滦州通世坤销服一体盛大开业! 参加本次开业庆典的有大运重卡营销中心副总经理助理张申、大运重卡营销中心销售总监倪世界、唐山滦都汽车贸易有限公司总经理王力…

深入学习html的步骤

推荐的学习步骤&#xff1a; 1. 深入了解HTML基础标签 列表 HTML提供有序列表(<ol>)和无序列表(<ul>)。 <h2>无序列表</h2> <ul><li>项目一</li><li>项目二</li><li>项目三</li> </ul><h2>…

[论文笔记]Query Rewriting for Retrieval-Augmented Large Language Models

引言 今天带来论文Query Rewriting for Retrieval-Augmented Large Language Models的笔记。 本篇工作从查询重写的角度介绍了一种新的框架&#xff0c;即重写-检索-阅读&#xff0c;而不是以前的检索-阅读方式&#xff0c;用于检索增强的LLM。关注的是搜索查询本身的适应性&…

线程本地化存储如何保证线程安全

线程本地化存储如何保证线程安全 1、背景2、详细分析1、背景 在并发编程中,可能最害怕听到一个词就是线程不安全。因为它意味着程序运行的时候,可能出现数据的读取或写入不准确等情况发生, 2、详细分析 可能对于每个工程师来说都不陌生,就是我们工作中常见的一个环节,…