使用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才知道你要从那个参数名中拿到参数名对应的数据体。
**结语:**有的时候弄这个会出现莫名的问题,这里就抽了时间做一个测试+总结,希望对大家有帮助

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

事件代理 浅谈

事件代理是一种将事件处理委托给父元素或祖先元素来管理的技术。当子元素触发特定事件时,该事件不会直接在子元素上进行处理,而是会冒泡到父元素或祖先元素,并在那里进行处理。这样做的好处是可以减少事件处理函数的数量,提高性能…

Centos 7.9 安装 tigervnc-server

环境:当前使用的 Centos 7.9 的光盘作为的本地源。 1 检查是否已安装 tigervnc [rootlocalhost /]# rpm -q tigervnc tigervnc-server 未安装软件包 tigervnc tigervnc-server-1.8.0-21.el7.x86_64 如果安装过卸掉 卸载: rpm -e [rootlocalhost /]# rpm -e tige…

Springboot 集成 Consul 实现服务注册中心-05

因为后续很多模块都要用到注册中心,所以此处先实现此模块。 Consul简介 Consul是一个开源的服务发现和配置管理工具,具有跨平台、运行高效等特点。它由HashiCorp公司开发,并使用Go语言编写。Consul主要用于实现分布式系统中的服务发现、健康…

代码随想录Day 41|Leetcode|Python|198.打家劫舍 ● 213.打家劫舍II ● 337.打家劫舍III

198.打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。 给定一个代表每个…

搭建私有仓库Nexus的流程以及npm包的开发和发布

搭建私有仓库 Nexus 的流程(Ubuntu)以及 npm 包的开发和发布 本文档是关于在 Ubuntu 上面搭建 Nexus,以及制作 npm 包并发布到 Nexus 的流程说明。 关于 Ubuntu Ubuntu 是一个基于 Linux 的操作系统,通常会用在服务器或者嵌入式…

luceda ipkiss教程 71:统计线路中器件的个数

**案例分享:**统计线路中某一器件的个数 如,统计SplitterTree中mmi的个数: 所有代码如下: # Copyright (C) 2020 Luceda Photonicsfrom si_fab import all as pdk from ipkiss3 import all as i3class GeneralizedSplitterTree…

手机恢复出厂设置会怎么样?一切回到了原点?

随着智能手机的普及,我们每天都在与手机紧密互动,里边存储了大量的个人信息和应用数据。然而,有时候我们会遇到手机卡顿、应用崩溃或数据丢失的问题。这时,恢复出厂设置成为了许多人的选择。那么,手机恢复出厂设置会怎…

专项技能训练五《云计算网络技术与应用》实训8-1:建立基于OpenvSwitch的GRE隧道

文章目录 建立基于OpenvSwitch的GRE隧道1. 使用VMware安装2个CentOS 7虚拟机,安装时记得都开启CPU虚拟化,第一台命名为“Docker”,第二台命名为“KVM”。2. 安装完虚拟机后,进入虚拟机,修改网络配置(onboot…

数据序列包分析

基于数据序列包分析各部分的内容及含义,可能会考大题 基于本例分析,每部分含义如下: 时间(Time): 时间戳显示了数据包在网络中被捕获的具体时间。在本例中,如"0.000000"表示第一个数据…

Golang | Leetcode Golang题解之第75题颜色分类

题目&#xff1a; 题解&#xff1a; func sortColors(nums []int) {p0, p2 : 0, len(nums)-1for i : 0; i < p2; i {for ; i < p2 && nums[i] 2; p2-- {nums[i], nums[p2] nums[p2], nums[i]}if nums[i] 0 {nums[i], nums[p0] nums[p0], nums[i]p0}} }

共用nacos造成的开发问题记录

目录 1.需求提出 2.系统架构 3.问题抛出 4.解决办法 1.配置私有命名空间 2.给服务加后缀 1.需求提出 本地调试用到哪个服务启动哪个服务&#xff0c;其他支持服务调用测试环境上的&#xff0c;目的是避免本地启动多个服务&#xff0c;消耗电脑配置。 2.系统架构 项目是…

im(即时通讯)是什么?

在当今数字化时代&#xff0c;即时通讯&#xff08;IM&#xff09;已经成为企业内部沟通与协作中不可或缺的工具。作为一种实时的即时通讯方式&#xff0c;IM能够极大提高团队成员之间的沟通效率&#xff0c;帮助企业快速响应变化&#xff0c;并增强内部协作与创新能力。 Work…

猫不仅吃猫粮,还可以吃这种食物,这些主食冻干喵吃了会开心哦

随着科学养猫的普及&#xff0c;主食冻干喂养越来越受欢迎&#xff0c;主食冻干喂养对猫的好处很多&#xff0c;它符合猫咪的天性&#xff0c;可以提供全面的营养&#xff0c;保持牙齿和牙龈的健康&#xff0c;还有助于维持健康的消化系统。所以铲屎官们不要在局限只给猫咪喂猫…

无需设置环境变量,Linux下最正确的Java离线安装方式

背景 公司研发网络是离线环境&#xff0c;需要安装Java环境&#xff0c;网上教程大多是在线安装或者通过设置环境变量安装&#xff0c;设置环境变量的方式是最常见的&#xff0c;但确隐藏了很多坑&#xff0c;例如环境变量有时候会不生效&#xff0c;如果你的程序通过systemd启…

6 7 8 9 11 12 15 17 18 20 22cm散热风扇防护网风扇金属网罩

品牌&#xff1a;威驰 颜色分类&#xff1a;60mm/6cm金属网,80mm/8cm金属网,92mm/9.2cm金属网,110mm/11cm金属网,120mm/12cm金属网,150mm/15cm金属网,172mm/17.2cm金属网,200mm/20cm金属网,280mm/28cm金属网 1产品参数&#xff0c;防护网罩60 80 90 110 120 125 145 150 180…

46.乐理基础-音符的组合方式-延音线

以四分音符为一拍的时候想要某个音符的时长为1.25拍的时候&#xff0c;没法表示出来&#xff0c;使用普通的音符、加了附点、或复附点的音符就是没办法表示出1.25拍。 最后一种组合音符拍号的记号&#xff0c;延音线&#xff0c;如下图&#xff0c;以四分音符为一拍&#xff0…

打造高效协作的领导班子:实践与策略

随着市场竞争的加剧&#xff0c;高效协作的领导班子对于组织的成功至关重要。本文旨在从实践与策略两个维度&#xff0c;深入剖析如何构建并优化高效协作的领导班子&#xff0c;进而提升组织的整体效能。 一、引言 在快速变化的时代背景下&#xff0c;领导班子的高效协作成为组…

从项目开始学习Vue——02(若依框架)

往期&#xff1a; 从项目开始学习Vue——01 目录标题 一、基础插件&#xff08;一&#xff09;路由Vue Router&#xff08;二&#xff09;导航守卫&#xff08;路由拦截器&#xff09;二、Vuex&#xff08;一&#xff09;什么是VuexVuex的部分介绍内容&#xff1a; &#xff08…

LabVIEW学习记录4-局部变量、全局变量、共享变量

【LabVIEW】局部变量、全局变量、共享变量 一、变量定义二、内存分配三、竞争状态四、变量创建及简单使用示例4.1 局部变量4.1.1 局部变量的创建4.1.2 局部变量的编程实例 4.2 全局变量4.2.1 创建4.2.2 调用4.2.3 编程实例 4.3 共享变量 一、变量定义 LabVIEW&#xff08;Labor…

Spring Boot与RSocket实现高效实时数据通信

作者介绍&#xff1a;✌️大厂全栈码农|毕设实战开发&#xff0c;专注于大学生项目实战开发、讲解和毕业答疑辅导。 推荐订阅精彩专栏 &#x1f447;&#x1f3fb; 避免错过下次更新 Springboot项目精选实战案例 更多项目&#xff1a;CSDN主页YAML墨韵 学如逆水行舟&#xff0c…