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

这篇文章主要讲解了“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的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!