詳解Mybatis 傳遞參數(shù)類(lèi)型為L(zhǎng)ist的取值問(wèn)題
問(wèn)題描述:
參數(shù)傳遞為L(zhǎng)ist時(shí):
當(dāng)傳遞一個(gè) List 實(shí)例或者數(shù)組作為參數(shù)對(duì)象傳給 Mybatis。此時(shí),Mybatis 會(huì)自動(dòng)將它包裝在一個(gè) Map 中,用名稱(chēng)在作為鍵。List 實(shí)例將會(huì)以“l(fā)ist” 作為鍵,而數(shù)組實(shí)例將會(huì)以“array”作為鍵。所以,當(dāng)我們傳遞的是一個(gè)List集合時(shí),mybatis會(huì)自動(dòng)把我們的list集合包裝成以list為Key值的map。
DAO 層:
List<User> selectUserByIDs( List IDs);
XML文件:
<select parameterType='java.util.List' resultType='user'> select * from user <where> <if test='IDs != null and IDs.size() >0'><foreach collection='IDs' open=' and id in (' close=')' item='uid' separator=','> #{uid}</foreach> </if> </where></select>
報(bào)錯(cuò)信息:
org.apache.ibatis.binding.BindingException: Parameter ‘IDs’ not found. Available parameters are [collection, list]
解決方法:
方法一:將我們的XML中collection屬性值直接設(shè)置為list
DAO 層:
List<User> selectUserByIDs( List IDs);
XML文件:
<select parameterType='java.util.List' resultType='user'> select * from user <where> <if test='list != null and list.size() >0'><foreach collection='list' open=' and id in (' close=')' item='uid' separator=','> #{uid}</foreach> </if> </where></select>
方法二: 利用注解@Param指定我們的入?yún)⒚Q(chēng)
DAO層:
List<User> selectUserByIDs(@Param('IDs') List IDs);
XML文件:
<select parameterType='java.util.List' resultType='user'> select * from user <where> <if test='IDs != null and IDs.size() >0'><foreach collection='IDs' open=' and id in (' close=')' item='uid' separator=','> #{uid}</foreach> </if> </where></select>
到此這篇關(guān)于詳解Mybatis 傳遞參數(shù)類(lèi)型為L(zhǎng)ist的取值問(wèn)題的文章就介紹到這了,更多相關(guān)Mybatis 傳遞參數(shù)類(lèi)型為L(zhǎng)ist的取值內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 如何安裝MySQL 壓縮包2. MariaDB中1045權(quán)限錯(cuò)誤導(dǎo)致拒絕用戶訪問(wèn)的錯(cuò)誤解決方法3. Sql Server 壓縮數(shù)據(jù)庫(kù)日志文件的方法4. Oracle數(shù)據(jù)庫(kù)的兩種授權(quán)收費(fèi)方式詳解5. 實(shí)例講解MySQL 慢查詢(xún)6. 關(guān)于Oracle的Dual表7. DB2數(shù)據(jù)庫(kù)控制中心亂碼問(wèn)題解決方法集合8. 詳解MySQL 慢查詢(xún)9. 簡(jiǎn)化 DB2 for i5/OS 索引建議10. MySQL存儲(chǔ)過(guò)程的查詢(xún)命令介紹

網(wǎng)公網(wǎng)安備