生活随笔
收集整理的這篇文章主要介紹了
MyBatis传入参数为list、数组、map写法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.foreach簡單介紹:
foreach的主要用在構建in條件中,它可以在SQL語句中進行迭代一個集合。
foreach元素的屬性主要有item,index,collection,open,separator,close。
item表示集合中每一個元素進行迭代時的別名,
index指定一個名字,用于表示在迭代過程中,每次迭代到的位置,
open表示該語句以什么開始,
separator表示在每次進行迭代之間以什么符號作為分隔符,
close表示以什么結束,
collection屬性是在使用foreach的時候最關鍵的也是最容易出錯的,該屬性是必須指定的,但是在不同情況下,該屬性的值是不一樣的,主要有一下3種情況:?
(1)如果傳入的是單參數且參數類型是一個List的時候,collection屬性值為list .
(2)如果傳入的是單參數且參數類型是一個array數組的時候,collection的屬性值為array .
(3)如果傳入的參數是多個的時候,我們就需要把它們封裝成一個Map了,當然單參數也可以封裝成map,實際上如果你在傳入參數的時候,在MyBatis里面也是會把它封裝成一個Map的,map的key就是參數名,所以這個時候collection屬性值就是傳入的List或array對象在自己封裝的map里面的key.
(4)如果傳入的是單個參數且參數類型為List的時候,使用@Param()注釋參數名字,那么collection屬性值為參數名字。例:[2]
Dao:
List<User> findListByIds(@Param("idList")List<String> idList);
XML
<select id="findListByIds" parameterType="java.util.List" resultType="User">select * from t_user where id in<foreach item="item" index="index" collection="idList" open="(" separator="," close=")">#{item}</foreach>
</select>
2.實踐-實體類
[java]?view plaincopy
public?class?Employees?{??????private?Integer?employeeId;??????private?String?firstName;??????private?String?lastName;??????private?String?email;??????private?String?phoneNumber;??????private?Date?hireDate;??????private?String?jobId;??????private?BigDecimal?salary;??????private?BigDecimal?commissionPct;??????private?Integer?managerId;??????private?Short?departmentId;??}????3.實踐-XML
[html]?view plaincopy
??????<select?id="getEmployeesListParams"?resultType="Employees">??????????select?*??????????from?EMPLOYEES?e??????????where?e.EMPLOYEE_ID?in??????????<foreach?collection="list"?item="employeeId"?index="index"??????????????open="("?close=")"?separator=",">??????????????#{employeeId}??????????</foreach>??????</select>??????????????<select?id="getEmployeesArrayParams"?resultType="Employees">??????????select?*??????????from?EMPLOYEES?e??????????where?e.EMPLOYEE_ID?in??????????<foreach?collection="array"?item="employeeId"?index="index"??????????????open="("?close=")"?separator=",">??????????????#{employeeId}??????????</foreach>??????</select>??????????????<select?id="getEmployeesMapParams"?resultType="Employees">??????????select?*??????????from?EMPLOYEES?e??????????<where>??????????????<if?test="departmentId!=null?and?departmentId!=''">??????????????????e.DEPARTMENT_ID=#{departmentId}??????????????</if>??????????????<if?test="employeeIdsArray!=null?and?employeeIdsArray.length!=0">??????????????????AND?e.EMPLOYEE_ID?in??????????????????<foreach?collection="employeeIdsArray"?item="employeeId"??????????????????????index="index"?open="("?close=")"?separator=",">??????????????????????#{employeeId}??????????????????</foreach>??????????????</if>??????????</where>??????</select>??4.實踐-Mapper
[java]?view plaincopy
public?interface?EmployeesMapper?{?????????List<Employees>?getEmployeesListParams(List<String>?employeeIds);????????List<Employees>?getEmployeesArrayParams(String[]?employeeIds);????????List<Employees>?getEmployeesMapParams(Map<String,Object>?params);??}??原文出處:
[1] zhangqifeng92, MyBatis傳入參數為list、數組、map寫法, https://blog.csdn.net/s592652578/article/details/52871884
[2] 實踐經驗,親測可用
轉載于:https://www.cnblogs.com/ryelqy/p/10104070.html
總結
以上是生活随笔為你收集整理的MyBatis传入参数为list、数组、map写法的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。