欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java?Mybatis?foreach嵌套foreach?List<list<Object>>問(wèn)題

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

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

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

動(dòng)態(tài)生成sql語(yǔ)句的查詢條件,這個(gè)時(shí)候我們就可以用mybatis的foreach了

foreach元素的屬性

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

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

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

舉個(gè)例子

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

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

  • 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)List的時(shí)候,collection屬性值為list .
  • 如果傳入的是單參數(shù)且參數(shù)類型是一個(gè)array數(shù)組的時(shí)候,collection的屬性值為array .
  • 如果傳入的參數(shù)是多個(gè)的時(shí)候,我們就需要把它們封裝成一個(gè)Map了,當(dāng)然單參數(shù)也可以封裝成map,實(shí)際上如果你在傳入?yún)?shù)的時(shí)候,在MyBatis里面也是會(huì)把它封裝成一個(gè)Map的,map的key就是參數(shù)名,所以這個(gè)時(shí)候collection屬性值就是傳入的List或array對(duì)象在自己封裝的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: 也就是這個(gè)
    			List<List<Map<String, Object>>> mapsList = new ArrayList<>();
	-->
    <!-- mapListData: 也就是這個(gè)
 			    List<Map<String, Object>> maps = new ArrayList<>();
        		List<Map<String, Object>> maps1 = new ArrayList<>();
	-->
    <!-- map: 也就是這個(gè)
 			    Map<String, Object> map = new HashMap<>();
	-->
	 <!-- separator=",": 這個(gè)重要是在每次循環(huán)的最后加上,-->
	 <!-- close=",": 這個(gè)是在所有都循環(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é)

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

相關(guān)文章

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

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

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

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

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

    springSecurity之AuthenticationProvider用法解析

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

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

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

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

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

    RestTemplate實(shí)現(xiàn)發(fā)送帶headers的GET請(qǐng)求

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

    Java文檔注釋用法+JavaDoc的使用說(shuō)明

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

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

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

    Java8生成時(shí)間方式及格式化時(shí)間的方法實(shí)例

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

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

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

最新評(píng)論