Mybatis foreach用法解析--對(duì)于list和array
foreach用法--對(duì)于list和array
foreach的主要用在構(gòu)建in條件中,它可以在SQL語(yǔ)句中進(jìn)行迭代一個(gè)集合。
foreach元素的屬性主要有 item,index,collection,open,separator,close。
item表示集合中每一個(gè)元素進(jìn)行迭代時(shí)的別名,index指定一個(gè)名字,用于表示在迭代過(guò)程中,每次迭代到的位置,open表示該語(yǔ)句以什么開(kāi)始,separator表示在每次進(jìn)行迭代之間以什么符號(hào)作為分隔 符,close表示以什么結(jié)束。
在使用foreach的時(shí)候最關(guān)鍵的也是最容易出錯(cuò)的就是collection屬性,該屬性是必須指定的,但是在不同情況 下,該屬性的值是不一樣的,主要有一下3種情況:
1.如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)List的時(shí)候,collection屬性值為list
2.如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)array數(shù)組的時(shí)候,collection的屬性值為array
3.如果使用Map封裝了,collection的屬性值為對(duì)應(yīng)的Key
4.parameterType為list,java.util.List,java.util.ArrayList均可以,切記不可以為Array.
建表語(yǔ)句和表的數(shù)據(jù),以及范例如下

第1種
DAO:
public List<User> findByIdList(List<String> idList);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="list"> ?<!-- parameterType="java.util.List" 也正確 -->
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="list" item="id" open="(" separator="," close=")">
?? ??? ?#{id}
?? ?</foreach>
</select>2018-02-04 14:44:18,015 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (66277ms)] - ==>
Preparing: SELECT id, username, password, sex FROM t_user WHERE id in ( ? , ? , ? )
2018-02-04 14:44:18,015 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (66277ms)] - ==>
Parameters: 1(String), 2(String), 3(String)
2018-02-04 14:44:18,062 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (66324ms)] - <==
Total: 3
第2種
DAO:
public List<User> findByIdList(List<String> idList);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="list"> ?<!-- parameterType="java.util.List" 也正確 -->
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="list" item="item123" open="(" separator="," close=")">
?? ??? ?#{item123}
?? ?</foreach>
</select>2018-02-04 14:48:25,654 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (16876ms)] - ==>
Preparing: SELECT id, username, password, sex FROM t_user WHERE id in ( ? , ? , ? )
2018-02-04 14:48:25,654 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (16876ms)] - ==>
Parameters: 1(String), 2(String), 3(String)
2018-02-04 14:48:25,654 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (16876ms)] - <==
Total: 3
第3種
DAO:
public List<User> findByIdList(List<String> idList);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="java.util.List">
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="List" item="item123" open="(" separator="," close=")"> ? <!-- 這里collection="List"報(bào)錯(cuò) -->
?? ??? ?#{item123}
?? ?</foreach>
</select>org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException:
Parameter 'List' not found. Available parameters are [list]
第4種
SERVICE:
public List<User> findByIdList(List<String> idList) {
?? ?Map<String, Object> map = new HashMap<String, Object>();
?? ?map.put("List123", idList);
?? ?return userDao.findByIdList(map);
}DAO:
public List<User> findByIdList(Map<String, Object> map);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="java.util.List">
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="List123" item="item123" open="(" separator="," close=")"> ? <!-- 使用Map封裝,key是List123 -->
?? ??? ?#{item123}
?? ?</foreach>
</select>2018-02-04 15:10:46,794 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (14878ms)] - ==>
Preparing: SELECT id, username, password, sex FROM t_user WHERE id in ( ? , ? , ? )
2018-02-04 15:10:46,794 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (14878ms)] - ==>
Parameters: 1(String), 2(String), 3(String)
2018-02-04 15:10:46,809 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (14893ms)] - <==
Total: 3
第5種
SERVICE:
public List<User> findByIdList(String[] idArray) {
?? ?Map<String, Object> map = new HashMap<String, Object>();
?? ?map.put("Array123", idArray);
?? ?return userDao.findByIdList(map);
}DAO:
public List<User> findByIdList(Map<String, Object> map);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="array"> ?<!-- 這里使用array會(huì)報(bào)錯(cuò) -->
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="Array123" item="item123" open="(" separator="," close=")">
?? ??? ?#{item123}
?? ?</foreach>
</select>Caused by: org.apache.ibatis.builder.BuilderException: Error parsing Mapper XML.
Cause: org.apache.ibatis.builder.BuilderException: Error resolving class.
Cause: org.apache.ibatis.type.TypeException: Could not resolve type alias 'array'.
Cause: java.lang.ClassNotFoundException: Cannot find class: array
第6種
SERVICE:
public List<User> findByIdList(String[] idArray) {
?? ?Map<String, Object> map = new HashMap<String, Object>();
?? ?map.put("Array123", idArray);
?? ?return userDao.findByIdList(map);
}DAO:
public List<User> findByIdList(Map<String, Object> map);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="list"> ? <!-- parameterType="java.util.List" 或者 parameterType="java.util.ArrayList" 均正確 -->?
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="Array123" item="item123" open="(" separator="," close=")">
?? ??? ?#{item123}
?? ?</foreach>
</select>2018-02-04 15:23:07,928 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (43730ms)] - ==>
Preparing: SELECT id, username, password, sex FROM t_user WHERE id in ( ? , ? , ? )
2018-02-04 15:23:07,928 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (43730ms)] - ==>
Parameters: 1(String), 2(String), 3(String)
2018-02-04 15:23:07,928 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (43730ms)] - <==
Total: 3
第7種
DAO:
public List<User> findByIdList(String[] idArray);
SQL:
<select id="findByIdList" resultMap="resultMap" parameterType="java.util.ArrayList">
?? ?SELECT
?? ?<include refid="columnSql"></include>
?? ?FROM t_user
?? ?WHERE id in
?? ?<foreach collection="array" item="item123" open="(" separator="," close=")">
?? ??? ?#{item123}
?? ?</foreach>
</select>2018-02-04 15:32:44,682 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (21575ms)] - ==>
Preparing: SELECT id, username, password, sex FROM t_user WHERE id in ( ? , ? , ? )
2018-02-04 15:32:44,682 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (21575ms)] - ==>
Parameters: 1(String), 2(String), 3(String)
2018-02-04 15:32:44,682 -[DEBUG] method:[com.springmvc.dao.UserDao.findByIdList (21575ms)] - <==
Total: 3
<sql id="columnSql">
<trim suffixOverrides=","> <!-- suffixOverrides此時(shí)的作用是去除最后一個(gè)逗號(hào) -->
id,
username,
password,
sex,
</trim>
</sql>以上基于JDK1.8。日志為親測(cè)。僅為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java并發(fā)之ArrayBlockingQueue詳細(xì)介紹
這篇文章主要介紹了java并發(fā)之ArrayBlockingQueue詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2017-05-05
IDEA 2020.2 +Gradle 6.6.1 + Spring Boot 2.3.4 創(chuàng)建多模塊項(xiàng)目的超詳細(xì)教程
這篇文章主要介紹了IDEA 2020.2 +Gradle 6.6.1 + Spring Boot 2.3.4 創(chuàng)建多模塊項(xiàng)目的教程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
idea構(gòu)建web項(xiàng)目的超級(jí)詳細(xì)教程
好多朋友在使用IDEA創(chuàng)建項(xiàng)目時(shí),總會(huì)碰到一些小問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于idea構(gòu)建web項(xiàng)目的超級(jí)詳細(xì)教程,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03
SpringBoot?+?proguard+maven多模塊實(shí)現(xiàn)代碼混淆的方法
這篇文章主要介紹了SpringBoot?+?proguard+maven多模塊實(shí)現(xiàn)代碼混淆的方法,多模塊跟單模塊一樣,在需要混淆模塊的pom文件中加入proguard依賴及配置,本文給大家講解的非常詳細(xì),感興趣的朋友一起看看吧2024-02-02
springboot jdbctemplate如何實(shí)現(xiàn)多數(shù)據(jù)源
這篇文章主要介紹了springboot jdbctemplate如何實(shí)現(xiàn)多數(shù)據(jù)源問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
springboot+mybatis-plus實(shí)現(xiàn)內(nèi)置的CRUD使用詳解
這篇文章主要介紹了springboot+mybatis-plus實(shí)現(xiàn)內(nèi)置的CRUD使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
IDEA解決@Slf4j中l(wèi)og報(bào)紅問(wèn)題
在IntelliJ IDEA中使用log.info()時(shí),如果出現(xiàn)錯(cuò)誤,通常是因?yàn)槿鄙貺ombok插件,以下是解決方法:打開(kāi)IntelliJ IDEA,進(jìn)入設(shè)置(File > Settings 或者 Ctrl+Alt+S),在Plugins部分點(diǎn)擊Browse repositories,搜索Lombok并安裝,安裝完成后,問(wèn)題通??梢越鉀Q2024-12-12
java微信開(kāi)發(fā)API第三步 微信獲取以及保存接口調(diào)用憑證
這篇文章主要為大家詳細(xì)介紹了java微信開(kāi)發(fā)API第二步,微信獲取以及保存接口調(diào)用憑證,感興趣的小伙伴們可以參考一下2016-06-06

