日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MyBatis传入参数为list、数组、map写法

發布時間:2023/12/10 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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
  • <!--List:forech中的collection屬性類型是List,collection的值必須是:list,item的值可以隨意,Dao接口中參數名字隨意?-->??
  • ????<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>??
  • ??
  • ????<!--Array:forech中的collection屬性類型是array,collection的值必須是:list,item的值可以隨意,Dao接口中參數名字隨意?-->??
  • ????<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>??
  • ??
  • ????<!--Map:不單單forech中的collection屬性是map.key,其它所有屬性都是map.key,比如下面的departmentId?-->??
  • ????<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写法的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。