这篇文章主要讲解了“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的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。