使用map类型的参数在mapper.xml中使用案例

使用map类型的参数在mapper.xml中使用案例

简介:在常见的开发中,对于参数的装载一般使用map类型方式,这样可以避免创建很多参数实体类,不管嵌套多层的数据参数都可以通过map拿取,对于嵌套多层的map,我们需要深层的一个集合在mapper.xml中遍历,如何拿到该值?
准备:
使用模拟请求数据:
在这里插入图片描述
这里,我需要拿到ids中的值进行遍历查找,但ids在aaa的下一层
后端接口,直接用map类型接收
在这里插入图片描述
然后直接看dao层
在这里插入图片描述

这里我先使用@Param注解
对应的mapper.xml的内容
在这里插入图片描述
解释:
m.aaa.ids:m是该参数名叫map的类型为map的数据的一个别名,这个别名是该@Param注解给的,用于mybatis框架区分dao层传入的多个参数(这里我只有一个)aaa是这个map类型的数据中最外层的key,通过m.aaa就进入了aaa的数据内容,ids是aaa中的,所以m.aaa.ids就进入了ids了,这里的m.aaa其实是类似于m.getProperty(“aaa”)这种,通过key-value的方式找到你需要的数据体内。
测试结果:
在这里插入图片描述
接下来我会一个个方式进行尝试看能否成功拿到ids,只改变dao层的参数和mapper.xml的获取ids方式
由于只有一个参数,我就不用@Param,也能找到,因为只有一个,不会产生歧义
在这里插入图片描述
在这里插入图片描述
这里我试图通过参数的名字map去找到ids,就是map.aaa.ids
结果:报错
在这里插入图片描述
在这里插入图片描述
根据报错信息可知:无法找到名叫aaa的数据,就是通过getProperty(“aaa”)找不到名叫aaa的东东
分析:dao层的map类型的名叫map的参数在mapper.xml中,mybatis是不认的,因为只有一个参数,他会直接打开map中的aaa所在的那一层,我这里aaa这一层的数据只有aaa这一个,下边我会弄多个,先暂时一个分析。
那么这个map.aaa.ids就和aaa.aaa.ids有点像,aaa中是没有名叫aaa的数据的,所以找不到,根据这个思路,这样写:aaa.ids会如何?
测试
在这里插入图片描述
在这里插入图片描述
成功到了ids层;
好,然后dao层我们试着用两个参数,当有多个参数后,默认有参数从左到右依次为param1,param2…的别名,这是mybatis自带的,
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
可以看到成功了
分析:这里的param1其实就是和@Param注解取的别名一样都在map类型的数据的数据名称这一层,和上边的一个参数直接就打开了这一层进入到数据体不一样。
那如果有多层,然后外边也有多层如何拿到ids?
测试:
内部有多层
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/896fe8f7e1904c388e7f21114e8f73f8.png

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
成功,然后使用注解@Param拿ids

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
成功了,那如果外部传了多层,内部也是多层,如何取到ids?
测试:
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
成功拿到
**总结:**我认为mapper.xml中的引用.,其实和通过key-value找值实质一样,比如aaa.bbb.ids的意思就是aaa通过getproperty(“bbb”)进入bbb层数据,然后bbb.getproperty(“ids”)进入ids层。
这里有点迷惑人的就是dao层如果只有一个参数,mapper.xml中会默认打开dao层的参数,直接进入该参数内,比如上边的例子,直接通过aaa.ids就行,不必再明确是dao层的那个参数名
然后其他的情况基本是一样的,都是通过dao层的参数名(可以是param1这种mybatis默认给的别名,也可以是@Param注解自定义别名),因为只有这样mybatis才知道你要从那个参数名中拿到参数名对应的数据体。
**结语:**有的时候弄这个会出现莫名的问题,这里就抽了时间做一个测试+总结,希望对大家有帮助

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

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

相关文章

云渲染动画300帧需要多久呢?瑞云渲染为你揭秘

在动画制作过程中,渲染的速度非常关键。对于一个项目需要渲染的300帧来说,由于硬件的限制,许多公司的设备可能无法快速完成这项任务。此时,借助云渲染服务的强大计算能力,可以显著减少完成时间,从而提速整个…

【Java基础】初识正则表达式

正则表达式只适用于字符串 匹配matches 实际使用的是String类中定义的方法boolean matches(String regex) public static void piPei( ){String regex"[1][356789]\\d{9}";boolean boo"14838384388".matches(regex);System.out.println(boo); }验证qq号…

构建无服务器数仓(二)Apache DolphinScheduler 集成以及 LOB 粒度资源消费分析

引言 在数据驱动的世界中,企业正在寻求可靠且高性能的解决方案来管理其不断增长的数据需求。本系列博客从一个重视数据安全和合规性的 B2C 金融科技客户的角度来讨论云上云下混合部署的情况下如何利用亚马逊云科技云原生服务、开源社区产品以及第三方工具构建无服务…

18 分页:介绍

目录 简单例子 页表存在哪里 列表中究竟有什么 分页:也很慢 内存追踪 小结 在解决大多数空间管理问题上面,操作系统有两种方法: 第一种就是将空间分割成不同长度的分片,类似于虚拟内存管理中的分段,但是这个方法…

电商平台自动回复脚本制作的流程!

随着电子商务的快速发展,电商平台在日常运营中面临着大量的客户咨询和服务需求,为了提高客户服务效率和质量,许多电商平台采用了自动回复脚本,以快速响应客户问题并提供准确的信息。 本文将详细介绍电商平台自动回复脚本制作的流…

Matten:视频生成与Mamba-Attention

Matten:视频生成与Mamba-Attention 摘要IntroductionRelated WorkMethodology Matten: Video Generation with Mamba-Attention 摘要 在本文中,作者介绍了Matten,一种具有Mamba-Attention架构的尖端潜在扩散模型,用于视频生成。在极小的计算…

带EXCEL附件邮件发送相关代码

1.查看生成的邮件 2.1 非面向对象的方式(demo直接copy即可) ​ REPORT Z12. DATA: IT_DOCUMENT_DATA TYPE SODOCCHGI1,IT_CONTENT_TEXT TYPE STANDARD TABLE OF SOLISTI1 WITH HEADER LINE,IT_PACKING_LIST TYPE TABLE OF SOPCKLSTI1 WITH HEADER LIN…

docker runc升级1.1.12

上传runc-1.1.12制品至中控机 874e970eaa932a97de9888344ae08f24 runc.arm64 将所有节点的runc文件备份 所有节点(包括master+node) vim host [all] 10.1.0.183 ansible_password=Bigdata@Ksyun123 ansible_user=root ansible_port=22 10.1.0.249 ansible_password=Bigdata…

关于 vs2019 c++ 20规范,STL 库提供的标准分配器 alloctor 及其 traits 及涉及分配器交换的全局函数 _Pocs

(1) 我们写 c 代码,使用 STL 库中的模板,很少自己写对象的分配器。用 STL 中的分配器也够用。研究 STL 中的分配器也可以为咱们自己写分配器提供参考。 咱们会遇到这样的场景,例如交换两个容器对象: list a ,b ; a .swap (b) ; 这…

自建XXL-JOB调度平台教程

一、XXL-JOB简介 XXL-JOB是一个分布式任务调度平台,其核心设计目标是开发迅速、学习简单、轻量级、易扩展。它支持通过Web界面进行管理调度任务,包括任务的增删改查、执行状态监控等。同时,XXL-JOB提供了Java、Spring Boot等多种接入方式&am…

40道 Nginx 高频面试题

Nginx 是一款轻量级的 Web 服务器、反向代理服务器,由于它的内存占用少,启动极快,高并发能力强,在互联网项目中广泛应用。那么关于 Nginx 的核心面试题有哪些呢?今天给大家整理了40道Nginx 高频面试题,最近…

麒麟kylin-v10系统,虚拟机kvm的使用

kvm的使用 虚拟机新建 点击选择对应的iso文件 选择相应的系统 (注意,如果这里没有相应的系统比如:windows,可以直接选择Generic default这是通用默认的意思) 选择cpu 完成即可 等待安装完毕 网络设置-ssh连接 虚拟…

Electron+Vue+pyinstaller服务打包

electron环境安装略 1. electron的入口文件配置test.js, 需要在package.json 配置文件中指定main: src/test.js const { app, BrowserWindow } require(electron)const createWindow () > {const win new BrowserWindow({width: 800,height: 600})// win.loadFile(inde…

红龙工业设备制造有限公司亮相2024杭州数字物流技术设备展

参展企业介绍 温州红龙工业设备制造有限公司成立于2015年11月。是中国先进的工业皮带设备研发制造和工业皮带整体解决方案运营服务商,现主营皮带接头机、皮带热压机、皮带接驳机、皮带打齿机、输送带打齿机、输送带分层级、输送带导条机、输送带裁切机、高频机等工业…

力扣HOT100 - 84. 柱状图中最大的矩形

解题思路&#xff1a; 单调栈 对于一个高度height[ i ]&#xff0c;找左右两边均严格小于它的值。 class Solution {public int largestRectangleArea(int[] heights) {int n heights.length;int[] left new int[n];int[] right new int[n];Deque<Integer> mono_st…

linux安装配置Docker保姆级教程

Docker到底是什么? Docker 是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中&#xff0c;然后发布到任何流行的 Linux或Windows操作系统的机器上&#xff0c;也可以实现虚拟化。 容器是完全使用沙箱机制&#xff0c;相互之间…

Fastchat + vllm + ray + Qwen1.5-7b 在2080ti 双卡上 实现多卡推理加速

首先先搞清各主要组件的名称与作用: FastChat FastChat框架是一个训练、部署和评估大模型的开源平台&#xff0c;其核心特点是&#xff1a; 提供SOTA模型的训练和评估代码 提供分布式多模型部署框架 WebUI OpenAI API Controller管理分布式模型实例 Model Worker是大模型服务…

智慧仓储可视化大屏,以最直观的形式展示海量数据。

智慧仓储可视化大屏是一种通过数据可视化技术&#xff0c;将仓储管理系统中的海量数据以图表、地图、仪表盘等形式直观展示在大屏上的解决方案。它可以帮助仓储管理人员更清晰地了解仓库的运营情况&#xff0c;从而做出更明智的决策。 智慧仓储可视化大屏通常包括以下功能和特点…

IP 地址追踪工具促进有效的 IP 管理

网络 IP 地址空间的结构、扫描和管理方式因组织的规模和网络需求而异&#xff0c;网络越大&#xff0c;需要管理的 IP 就越多&#xff0c;IP 地址层次结构就越复杂。因此&#xff0c;如果没有 IP 地址管理&#xff08;IPAM&#xff09;解决方案&#xff0c;IP 资源过度使用和地…

2024-05-10 Ubuntu上面使用libyuv,用于转换、缩放、旋转和其他操作YUV图像数据,测试实例使用I420ToRGB24

一、简介&#xff1a;libyuv 最初是由Google开发的&#xff0c;主要是为了支持WebRTC项目中的视频处理需求。用于处理YUV格式图像数据的开源库。它提供了一系列的函数&#xff0c;用于转换、缩放、旋转和其他操作YUV图像数据。 二、执行下面的命令下载和安装libyuv。 git clo…