前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mybatis循环map的一些技巧

mybatis循环map的一些技巧

作者头像
全栈程序员站长
发布2022-11-01 15:27:57
5800
发布2022-11-01 15:27:57
举报
文章被收录于专栏:全栈程序员必看

<foreach>标签的用法:

六个参数:

collection:要循环的集合

index:循环索引(不知道啥用。。)

item:集合中的一个元素(item和collection,按foreach循环理解)

open:以什么开始

close:以什么结束

separator:循环内容之间以什么分隔

daoImpl.java:

代码语言:javascript
复制
public Manager selectManager(Map<String, String> params) throws Exception {		if(params==null){			logger.info("!!!异常!!!根据参数查询菜单信息传入的参数为null,返回null");			return null;		}				Map<String,Object> f_params=new HashMap<String,Object>();		f_params.put("params", params);				return (Manager) findForObject("managerMapper.selectManager", f_params);	}

mapper.xml

代码语言:javascript
复制
<select id="selectManager" parameterType="HashMap" resultType="Manager">
		select * from manager where ISDELETED='0'
		
		<foreach collection="params.keys" item="k" open="and" separator="and"> 
		    <if test="null != params[k]">  
				${k} = #{params.${k}}
		    </if>
		</foreach>
		
	</select>

——————下面转载,不完整———————————————

循环key:

[java] view plain copy

  1. <foreach collection=“condition.keys” item=“k” separator=“and”>
  2. ${k} = #{k}
  3. </foreach>

循环values

[java] view plain copy

  1. <foreach collection=“condition.values” item=“v” separator=“and”>
  2. ${v} = #{v}
  3. </foreach>

循环获取key和值:

[java] view plain copy

  1. <foreach collection=“condition.keys” item=“k” separator=“and”>
  2. <if test=“null != condition[k]”>
  3. {k} = {condition[k]}
  4. </if>
  5. </foreach>

通常我们设置值的时候,会以#{}的方式,而不是${},如下

[java] view plain copy

  1. <foreach collection=“condition.keys” item=“k” separator=“and”>
  2. <if test=“null != condition[k]”>
  3. ${k} = #{condition[k]}
  4. </if>
  5. </foreach>

但是用这种方式,会发现,取不了值了,${condition[k]} 能取的出值,但#{condition[k]} 取出来的值却实null,正确的写法应该是:

[java] view plain copy

  1. <foreach collection=“condition.keys” item=“k” separator=“and”>
  2. <if test=“null != condition[k]”>
  3. {k} = #{condition[{k}]}
  4. </if>
  5. </foreach>

PS:

{k} = #{condition[{k}]} 是不太好用在mybatis3.3下

修改成 {k} = #{condition.{k}} 是好用的

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/179584.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月21日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档