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

mybatis雙重foreach如何實現(xiàn)遍歷map中的兩個list數(shù)組

 更新時間:2024年09月24日 10:17:00   作者:flytalei  
本文介紹了如何解析前端傳遞的JSON字符串并在Java后臺動態(tài)構(gòu)建SQL查詢條件,首先,通過JSONArray.fromObject()將JSON字符串轉(zhuǎn)化為JSONArray對象,遍歷JSONArray,從中提取name和infos,構(gòu)建成Map對象用于Mybatis SQL映射

實現(xiàn)背景

前端傳值時可能會有多個字段傳遞過來,需要后臺將這多個字段拼接為 name in (? , ?) and name1 in (? , ?) and name2 in (? , ?) 作為sql查詢條件…

如下圖sql語句,即實現(xiàn)多個and xxx in(?,?,?) 拼接

select * from web_ztlc_provateequity WHERE
 cords in ( ? , ? , ?  ) 
 and productName in ( ? , ? , ? ) 
 and product_id in ( ? , ? , ? )

前端傳值的格式

前端傳遞的是json字符串,json中name和infos是一對具有對應(yīng)關(guān)系的對象,且json中會有多條這種對象,即此對象是一個數(shù)組。

而infos中也會有多條數(shù)據(jù),即infos也是一個數(shù)組對象。所以最終前端傳遞過來json格式如下

json字符串:
itemList:[{"name":"cords", "infos":["2", "2222", "2223","2224","2225","2226"] },
          {"name":"productName", "infos":["2號B","SAP智龍3號私募證券投資基金","一村金衍10號第1期"]}]

Debug斷點調(diào)試java如何解析json對象

綜上所述,后臺Java接口在獲取到j(luò)son字符串后,需要遍歷json中的兩個數(shù)組對象,即name和infos

		//模擬數(shù)據(jù)測試前端傳參
		String itemList="[{ \"name\":\"cords\", \"infos\":[ \"2\", \"2222\", \"2223\",\"2224\",\"2225\",\"2226\" ] },{ \"name\":\"productName\", \"infos\":[ \"2號B\",\"SAP智龍3號私募證券投資基金\",\"一村金衍10號第1期\" ] }]";
		//獲取前端傳過來的參數(shù)數(shù)組
        //String itemList = request.getParameter("itemList");
		if(!StringUtils.isEmpty(itemList)){
			//將參數(shù)數(shù)組轉(zhuǎn)化為json數(shù)組類型
			JSONArray jsonArray = JSONArray.fromObject(itemList);
			if(jsonArray.size()!=0){
				Map<String,Object> columnMap = new HashMap<>();
 				//遍歷jsonarray數(shù)組
				for(int i = 0;i < jsonArray.size(); i++) {
					net.sf.json.JSONObject job = jsonArray.getJSONObject(i);
					String name = job.getString("name");
					List<String> lists =job.getJSONArray("infos");
					if(lists.size()!= 0){
						columnMap.put(name,lists);
					}
				}
				hm.put("columnMap",columnMap);
			}else{
				return null;
			}
		}

第一步 JSONArray.fromObject()

JSONArray jsonArray = JSONArray.fromObject(itemList);

從上圖可以看出JSONArray.fromObject(itemList)后,jsonArray已經(jīng)size=2(解析出了兩條json對象,每條對象又由name和infos各自的鍵值對(key =>value)組成,name中name為key,cords為value(這里的cords就是后面我們sql語句中需要拼接的and條件的字段值);

infos中的key為infos,而value又是一個數(shù)組對象(這個數(shù)組里的各個對象,就是我們后面sql語句中需要拼接的in的條件))

第二步 遍歷jsonArray

由第一步可以看出此時jsonArray里已經(jīng)存放了數(shù)組下標(biāo)為0和1的兩條數(shù)據(jù),那么此時我們就挨個的取出這兩條數(shù)據(jù)(也就是遍歷啦)

第一次for循環(huán)0數(shù)組,取出0數(shù)組中的name和infos,可以看出我們聲明了一個lists數(shù)組,由來存放infos中的所以數(shù)值

如下圖,我們同時還聲明了一個columnMap的Map對象,此對象用來存儲從json中獲取到的name和infos。

將name和infos封裝成鍵值對(key=>value)的Map對象,將來傳遞給Mybatis的parameterType="hashmap"的入?yún)傩?通過key來找value。

每次for循環(huán)就放一個鍵值對對象進columnMap,我們這里測試數(shù)據(jù)只有兩條,所以columnMap最終會被放進兩個鍵值對對象即columnMap的size=2.

第三步 mybatis雙重foreach

此時mybatis雙重foreach的雛形就出來了,因為columnMap中已經(jīng)有2個key=>value對象了。也就意味著有多個key,而每個key又對應(yīng)多個value。所以此時mybais的foreach循環(huán)就得嵌套,第一次循環(huán)key,循環(huán)key時又得循環(huán)key對應(yīng)的多個value

最終需要foreach雙重遍歷的Map集合的數(shù)據(jù)結(jié)構(gòu)

columnMap為key的value中又存在多個key/value對象,columnMap的結(jié)構(gòu)如下

<select id="queryAllWebZtlcProvateequity" resultMap="BaseResultMap" parameterType="hashmap">
		select * from web_ztlc_provateequity
		<where>
			<if test="columnMap != null and columnMap !=''">
				<foreach item="item" collection="columnMap.entrySet()" index="key" >
				    and ${key} in
				    <foreach item="value" collection="item" open="(" close=")" separator=",">
					     #{value}
				    </foreach>
				</foreach>
			</if>
		</where>
	</select>

foreach標(biāo)簽說明

  • collection:需要遍歷的對象,以上代碼可以看出我寫的是collection="columnMap.entrySet()",columnMap是我封裝的Map對象,而entrySet()則是Map的內(nèi)置方法,存儲的是Map中的鍵值對集合,此時第一個foreach就是在遍歷Map中的key。
  • item:遍歷時每個元素遍歷出來時的別名,這個別名有用,我們第二次foreach是會用到,因為第一次foreach的是key集合,那么第二次foreach時就得遍歷key對應(yīng)的value集合。
  • index:表示索引,也就是遍歷集合中的數(shù)組下標(biāo),0,1,2,3......等,可以看出這里我填寫的標(biāo)簽屬性是index="key",下面and拼接時取得就是$key這個變量and ${key} in
  • open:in語句循環(huán)開始的符號,我們知道sql中in后面的條件是用()括起來的,所以這里我們填寫的屬性是open="("
  • close:in語句循環(huán)結(jié)束的符號,同上,有開始就有結(jié)束,所以這里我們填寫的屬性是close=")"
  • separator:多個條件拼接時的分隔符,我們知道in語句中會有多個條件即in(1,2,3,4)而多個條件使用逗號分割,所以這里我們填寫的屬性是separator=","

最終效果

最后由控制臺可以看出,我們已經(jīng)成功拼接了and xxx in (?,?,?)

總結(jié)

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

相關(guān)文章

  • JavaEE Cookie的基本使用細節(jié)

    JavaEE Cookie的基本使用細節(jié)

    本章我們將學(xué)習(xí)會話跟蹤技術(shù)中的Cookie與Session,它在我們整個JavaEE的知識體系中是非常重要的,本節(jié)我們先介紹Cookie,廢話不多說,直接上正文
    2022-12-12
  • mybatis多對多關(guān)聯(lián)實戰(zhàn)教程(推薦)

    mybatis多對多關(guān)聯(lián)實戰(zhàn)教程(推薦)

    下面小編就為大家?guī)硪黄猰ybatis多對多關(guān)聯(lián)實戰(zhàn)教程(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • JAVA提高第九篇 集合體系

    JAVA提高第九篇 集合體系

    這篇文章主要為大家詳細介紹了JAVA提高第九篇集合體系的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • MyBatis根據(jù)條件批量修改字段的方式

    MyBatis根據(jù)條件批量修改字段的方式

    這篇文章主要介紹了MyBatis根據(jù)條件批量修改字段的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Java交換map的key和value值的步驟和代碼示例

    Java交換map的key和value值的步驟和代碼示例

    在Java中,我們都知道直接交換Map的key和value是不被允許的,因為Map的接口設(shè)計是基于key-value對的,其中key是唯一的,并且是不可變的,所以本文給大家介紹了Java交換map的key和value值的步驟和代碼示例,需要的朋友可以參考下
    2024-09-09
  • java搭建一個Socket服務(wù)器響應(yīng)多用戶訪問

    java搭建一個Socket服務(wù)器響應(yīng)多用戶訪問

    本篇文章主要介紹了java搭建一個Socket服務(wù)器響應(yīng)多用戶訪問,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • 淺析SpringBoot及環(huán)境搭建過程

    淺析SpringBoot及環(huán)境搭建過程

    Spring Boot是由Pivotal團隊提供的全新框架,其設(shè)計目的是用來簡化新Spring應(yīng)用的初始搭建以及開發(fā)過程.這篇文章主要介紹了SpringBoot介紹及環(huán)境搭建,需要的朋友可以參考下
    2018-01-01
  • Java網(wǎng)絡(luò)編程之簡易聊天室的實現(xiàn)

    Java網(wǎng)絡(luò)編程之簡易聊天室的實現(xiàn)

    這篇文章主要為大家詳細介紹了如何利用Java語言實現(xiàn)一個簡易聊天室功能,可以實現(xiàn)運行客戶端和連接服務(wù)器,文中的示例代碼講解詳細,需要的可以了解一下
    2022-10-10
  • 關(guān)于Gateway路由匹配規(guī)則解讀

    關(guān)于Gateway路由匹配規(guī)則解讀

    本文詳細介紹了SpringCloudGateway的路由匹配規(guī)則,包括基本概念、常用屬性、實際應(yīng)用以及注意事項,路由匹配規(guī)則決定了請求如何被轉(zhuǎn)發(fā)到目標(biāo)服務(wù),是Gateway的核心功能之一,在配置路由時需要注意順序、性能和安全性
    2025-02-02
  • Springboot?上傳文件或頭像(MultipartFile、transferTo)

    Springboot?上傳文件或頭像(MultipartFile、transferTo)

    本文主要介紹了Springboot?上傳文件或頭像(MultipartFile、transferTo),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04

最新評論