MyBatis 是一个优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 的动态 SQL 功能是其一大特色,能够根据条件动态生成 SQL 语句。其中,<foreach>
标签是动态 SQL 中非常常用的一个标签,用于在 SQL 语句中遍历集合。
<foreach>
标签的基本用法
<foreach>
标签主要用于生成 SQL 语句中的 IN
子句,或者用于批量插入、更新等操作。其主要属性包括:
collection
:指定要遍历的集合,可以是 List、Set、数组或者 Map 的键。item
:集合中的每一个元素的别名。index
:集合中的元素的索引(对于 List 和数组是下标,对于 Map 是键)。open
:遍历开始前要添加的字符串。close
:遍历结束后要添加的字符串。separator
:每个元素之间的分隔符。
示例:使用 <foreach>
生成 IN
子句
假设我们有一个查询,需要根据一组 ID 来查询用户信息:
<select id="selectUsersByIds" resultType="User">
SELECT * FROM users
WHERE id IN
<foreach collection="idList"