mybatis在resultmap的子查询中使用传到mapper中的参数

发布时间:2024年01月15日

1.将要传递的参数作为虚拟列加入到select语句中

2.使用column进行虚拟列的数据传递,在子查询中就能直接使用了,等于号两边名字一样免得区分,只要是出现在夫查询select语句中的都能传递

3.在子查询中使用参数

上图

上述的方法只限单值变量

问题:如果传递的参数是个集合呢,比如list集合?

解决方法是在参数传到mapper中之前将list转化为string字符串,在mapper中使用的时候<foreach collection="menuIds.split(',')就可以了

import org.apache.commons.lang3.StringUtils;? ? ? ? //stringUtils是lang包下的

String menuIds=StringUtils.strip(menuId.toString(),"[]");去除两边的大括号

文章来源:https://blog.csdn.net/jishuai6p/article/details/135589136
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。