使用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?

测试:

内部有多层


成功,然后使用注解@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才知道你要从那个参数名中拿到参数名对应的数据体。

**结语:**有的时候弄这个会出现莫名的问题,这里就抽了时间做一个测试+总结,希望对大家有帮助

相关推荐
Coder码匠44 分钟前
Dockerfile 优化实践:从 400MB 到 80MB
java·spring boot
李慕婉学姐8 小时前
【开题答辩过程】以《基于JAVA的校园即时配送系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·开发语言·数据库
奋进的芋圆10 小时前
Java 延时任务实现方案详解(适用于 Spring Boot 3)
java·spring boot·redis·rabbitmq
sxlishaobin10 小时前
设计模式之桥接模式
java·设计模式·桥接模式
model200510 小时前
alibaba linux3 系统盘网站迁移数据盘
java·服务器·前端
荒诞硬汉10 小时前
JavaBean相关补充
java·开发语言
提笔忘字的帝国11 小时前
【教程】macOS 如何完全卸载 Java 开发环境
java·开发语言·macos
2501_9418824811 小时前
从灰度发布到流量切分的互联网工程语法控制与多语言实现实践思路随笔分享
java·开发语言
華勳全栈11 小时前
两天开发完成智能体平台
java·spring·go
alonewolf_9911 小时前
Spring MVC重点功能底层源码深度解析
java·spring·mvc