温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

mybatis框架下xml文件中foreach的使用方法

发布时间:2021-07-06 18:42:52 来源:亿速云 阅读:789 作者:chen 栏目:编程语言

这篇文章主要讲解了“mybatis框架下xml文件中foreach的使用方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mybatis框架下xml文件中foreach的使用方法”吧!

首先看看以下使用带来的问题:
<insert id="insertLabourBossList">
INSERT INTO
labour_boss
(name, phone, labour_company, project_id)
VALUES
<foreach collection="list" item="item" index="index" open="(" close=")" separator=",">
(#{item.name}, #{item.phone}, #{item.labourCompany}, #{item.projectId})
</foreach>
</insert>
解析结果:INSERT INTO labour_boss (name, phone, labour_company, project_id) VALUES ( (?, ?, ?, ?) , (?, ?, ?, ?) )


其实,这里需要的解析结果是:VALUES (?, ?, ?, ?) , (?, ?, ?, ?) ,而不是 VALUES ( (?, ?, ?, ?) , (?, ?, ?, ?) ) 原因分析:是foreach中open和close值设置不当引起的问题。


foreach标签中各属性的含义:

  • collection:集合参数的名称,即需要遍历的集合名

  • item:集合每个元素迭代时的别名

  • index:集合中元素迭代时的索引

  • open:集合迭代所生成的最终结果,以什么开始,比如以'('开始

  • close:集合迭代所生成的最终结果,以什么结束,比如以'(j结束

  • separator:迭代之间生成的元素的分隔符


修改:此处将open和close中的值去掉,为空 <insert id="insertLabourBossList">
INSERT INTO
labour_boss
(name, phone, labour_company, project_id)
VALUES
<foreach collection="list" item="item" index="index" open="" close="" separator=",">
(#{item.name}, #{item.phone}, #{item.labourCompany}, #{item.projectId})
</foreach>
</insert>\

感谢各位的阅读,以上就是“mybatis框架下xml文件中foreach的使用方法”的内容了,经过本文的学习后,相信大家对mybatis框架下xml文件中foreach的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI