亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java?Mybatis?foreach嵌套foreach?List<list<Object>>問題

 更新時間:2024年09月24日 09:20:58   作者:Dubbo-羅  
在MyBatis的mapper.xml文件中,foreach元素常用于動態(tài)生成SQL查詢條件,此元素包括item(必選,元素別名)、index(可選,元素序號或鍵)、collection(必選,指定迭代對象)、open、separator、close(均為可選,用于定義SQL結(jié)構(gòu))

Java Mybatis foreach嵌套foreach List<list<Object>>

在做mybatis的mapper.xml文件的時候,我們時常用到這樣的情況:

動態(tài)生成sql語句的查詢條件,這個時候我們就可以用mybatis的foreach了

foreach元素的屬性

主要有item,index,collection,open,separator,close。

  • item:集合中元素迭代時的別名,該參數(shù)為必選。
  • index:在list和數(shù)組中,index是元素的序號,在map中,index是元素的key,該參數(shù)可選
  • open:foreach代碼的開始符號,一般是(和close=")"合用。常用在in(),values()時。該參數(shù)可選
  • separator:元素之間的分隔符,例如在in()的時候,separator=","會自動在元素中間用“,“隔開,避免手動輸入逗號導(dǎo)致sql錯誤,如in(1,2,)這樣。該參數(shù)可選。
  • close:foreach代碼的關(guān)閉符號,一般是)和open="("合用。常用在in(),values()時。該參數(shù)可選。
  • collection:要做foreach的對象,作為入?yún)r,List對象默認(rèn)用"list"代替作為鍵,數(shù)組對象有"array"代替作為鍵,Map對象沒有默認(rèn)的鍵。當(dāng)然在作為入?yún)r可以使用@Param(“keyName”)來設(shè)置鍵,設(shè)置keyName后,list,array將會失效。

除了入?yún)⑦@種情況外,還有一種作為參數(shù)對象的某個字段的時候。

舉個例子

如果User有屬性List ids。入?yún)⑹荱ser對象,那么這個collection = “ids”.如果User有屬性Ids ids;其中Ids是個對象,Ids有個屬性List id;入?yún)⑹荱ser對象,那么collection = “ids.id”

在使用foreach的時候最關(guān)鍵的也是最容易出錯的就是collection屬性,該屬性是必須指定的,但是在不同情況下,該屬性的值是不一樣的,主要有一下3種情況:

  • 如果傳入的是單參數(shù)且參數(shù)類型是一個List的時候,collection屬性值為list .
  • 如果傳入的是單參數(shù)且參數(shù)類型是一個array數(shù)組的時候,collection的屬性值為array .
  • 如果傳入的參數(shù)是多個的時候,我們就需要把它們封裝成一個Map了,當(dāng)然單參數(shù)也可以封裝成map,實際上如果你在傳入?yún)?shù)的時候,在MyBatis里面也是會把它封裝成一個Map的,map的key就是參數(shù)名,所以這個時候collection屬性值就是傳入的List或array對象在自己封裝的map里面的key.
 public static void main(String[] args) {
        List<List<Map<String, Object>>> mapsList = new ArrayList<>();
        List<Map<String, Object>> maps = new ArrayList<>();
        List<Map<String, Object>> maps1 = new ArrayList<>();
        Map<String, Object> map = new HashMap<>();
        map.put("fydm","3212");
        map.put("ajbs","321200000006229");
        maps.add(map);
        Map<String, Object> map1 = new HashMap<>();
        map1.put("fydm","3212");
        map1.put("ajbs","321200000006229");
        maps.add(map1);
        List<Map<String, Object>> maps2 = new ArrayList<>();
        Map<String, Object> map2 = new HashMap<>();
        map2.put("fydm","3212");
        map2.put("ajbs","321200000006229");
        maps1.add(map2);
        Map<String, Object> map3 = new HashMap<>();
        map3.put("fydm","3212");
        map3.put("ajbs","321200000006229");
        maps1.add(map3);
        mapsList.add(maps);
        mapsList.add(maps1);
        for (List<Map<String, Object>> mapList : mapsList) {
            for (Map<String, Object> stringObjectMap : mapList) {
                System.out.println(stringObjectMap.get("fydm")+"----"+ stringObjectMap.get("ajbs"));
            }
        }
        baseMapper.insertInfoDocumentsBatch(mapsList);
}
<insert id="insertInfoDocumentsBatch" parameterType="java.util.List">
    insert ignore hlwft_documents
    (
        document_name,
        documents_number
    )
    values
    <!-- mapsList: 也就是這個
    			List<List<Map<String, Object>>> mapsList = new ArrayList<>();
	-->
    <!-- mapListData: 也就是這個
 			    List<Map<String, Object>> maps = new ArrayList<>();
        		List<Map<String, Object>> maps1 = new ArrayList<>();
	-->
    <!-- map: 也就是這個
 			    Map<String, Object> map = new HashMap<>();
	-->
	 <!-- separator=",": 這個重要是在每次循環(huán)的最后加上,-->
	 <!-- close=",": 這個是在所有都循環(huán)的最后加上,-->
    <foreach  item="mapListData" collection="mapsList" separator=","  index="index1">
        <foreach  item="map" collection="mapListData" separator="," index="index2">
            (
            #{map.fydm},
            #{map.ajbs}
            )
        </foreach>
    </foreach>
    <!-- 和Java for循環(huán)一致
    for (List<Map<String, Object>> mapListData: mapsList) {
            for (Map<String, Object> map : mapListData) {
                System.out.println(map.get("fydm")+"----"+ map.get("ajbs"));
            }
        }
        -->
</insert>

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文詳解Java中的監(jiān)聽器(Listener)

    一文詳解Java中的監(jiān)聽器(Listener)

    這篇文章主要介紹了Java中監(jiān)聽器(Listener)的相關(guān)資料,監(jiān)聽器模式是一種設(shè)計模式,用于處理異步事件和通知,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2025-03-03
  • java jni調(diào)用c函數(shù)實例分享(java調(diào)用c函數(shù))

    java jni調(diào)用c函數(shù)實例分享(java調(diào)用c函數(shù))

    Java代碼中調(diào)用C/C++代碼,當(dāng)然是使用JNI,JNI是Java native interface的簡寫,可以譯作Java原生接口,下面看實例吧
    2013-12-12
  • springSecurity之AuthenticationProvider用法解析

    springSecurity之AuthenticationProvider用法解析

    這篇文章主要介紹了springSecurity之AuthenticationProvider用法解析,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • Java?SpringBoot集成文件之如何使用POI導(dǎo)出Word文檔

    Java?SpringBoot集成文件之如何使用POI導(dǎo)出Word文檔

    這篇文章主要介紹了Java?SpringBoot集成文件之如何使用POI導(dǎo)出Word文檔,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下
    2022-08-08
  • JAVA8 lambda表達(dá)式權(quán)威教程

    JAVA8 lambda表達(dá)式權(quán)威教程

    本文主要給大家講解Java8中最重要的一個特征之一lambda表達(dá)式,本文通過實例圖文解說給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友跟隨小編一起學(xué)習(xí)下吧
    2021-05-05
  • RestTemplate實現(xiàn)發(fā)送帶headers的GET請求

    RestTemplate實現(xiàn)發(fā)送帶headers的GET請求

    這篇文章主要介紹了RestTemplate實現(xiàn)發(fā)送帶headers的GET請求,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Java文檔注釋用法+JavaDoc的使用說明

    Java文檔注釋用法+JavaDoc的使用說明

    這篇文章主要介紹了Java文檔注釋用法+JavaDoc的使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java中LinkedList的模擬實現(xiàn)

    Java中LinkedList的模擬實現(xiàn)

    本文主要介紹了Java中LinkedList的模擬實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Java8生成時間方式及格式化時間的方法實例

    Java8生成時間方式及格式化時間的方法實例

    這篇文章主要給大家介紹了關(guān)于Java8生成時間方式及格式化時間的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Java三種求水仙花數(shù)的方法

    Java三種求水仙花數(shù)的方法

    本篇文章通過求水仙花數(shù)的實例來讓大家對JAVA求數(shù)的概念和方法有更深入的理解和應(yīng)用,學(xué)習(xí)參考下吧。
    2018-02-02

最新評論