解決Mybatis中foreach嵌套使用if標(biāo)簽對(duì)象取值的問(wèn)題
foreach嵌套使用if標(biāo)簽對(duì)象取值問(wèn)題
最近做項(xiàng)目過(guò)程中,涉及到需要在 Mybatis 中 使用 foreach 進(jìn)行循環(huán)讀取傳入的查詢條件,動(dòng)態(tài)拼接SQL語(yǔ)句,接口傳入的查詢條件格式:{"advanceSearchList":[{"searchType":10,"searchText":"12"}]} ,根據(jù)我定義的參數(shù)格式,需要在 Mybatis中動(dòng)態(tài)去循環(huán)讀取 advanceSearchList 集合中的json對(duì)象,并根據(jù) json對(duì)象中的 searchType 做不同的處理,需要在 foreach 中嵌套 if 標(biāo)簽進(jìn)行判斷使用。
大體格式
? ? ? ? <foreach collection="advanceSearchList" item="item" index="index" >
? ? ? ? ? ? <if test="xxx == 10 ">
? ? ? ? ? ? ? ? and abc like CONCAT('%', ddd, '%')
? ? ? ? ? ? </if>
? ? ? ? </foreach>因?yàn)楫?dāng)前 foreach 中獲取到的 item 是一個(gè)json對(duì)象,涉及到在 if 標(biāo)簽中獲取當(dāng)前對(duì)象中指定屬性的值,一時(shí)腦抽,沒(méi)有想起來(lái)取值辦法,咨詢?nèi)f能的度娘沒(méi)有得到滿意的回復(fù),經(jīng)過(guò)自己傻瓜式的嘗試,終于找到了取值方法,特此記錄下:
解決辦法
Mybatis 在 foreach 標(biāo)簽中使用 if 標(biāo)簽獲取對(duì)象屬性方法:
直接通過(guò) 對(duì)象.屬性 的方式獲?。。。?!對(duì),你沒(méi)看錯(cuò),就是直接通過(guò) 對(duì)象.屬性 的方式獲?。。?!
例如:當(dāng)前foreach 循環(huán)獲取的對(duì)象是 item,想要獲取對(duì)象中的 searchType ,直接就是 item.searchType 即可……
代碼如下
? ? ? ? <foreach collection="advanceSearchList" item="item" index="index" >
? ? ? ? ? ? <if test="item.searchType == 10 ">
? ? ? ? ? ? ? ? and abc like CONCAT('%', #{item.searchText}, '%')
? ? ? ? ? ? </if>
? ? ? ? </foreach>Mybatis if 語(yǔ)句嵌套
在使用mybatis的時(shí)候,可以在 if 標(biāo)簽下面加上if標(biāo)簽。
比如要對(duì)這個(gè)sql語(yǔ)句進(jìn)行改進(jìn)。
select a.* from emp a?
inner join dept b
on a.deptno = b.no
where ?b.place= #{place}要求
如果 傳入的 地點(diǎn) 是 North Korea 那么 符合 a中的條件也可以。
a.male = 'M' or a.age ?bewteen ?20 and 30?
where語(yǔ)句可以這么寫(xiě)
select * from emp e?
<where>
<if test="_parameter.place != null and _parameter.place != '' ">
and?
<if test="_parameter.place == 'North Korea' "> ?( ?</if>
b.place = #{place}
<if test="_parameter.place == 'North Korea' ">
or a.male = 'M' or a.ge between 20 and 30 ?)
</if>
</if>
</where>注意里面的括號(hào)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java 漢諾塔Hanoi遞歸、非遞歸(仿系統(tǒng)遞歸)和非遞歸規(guī)律 實(shí)現(xiàn)代碼
漢諾塔(Hanoi) 算法Java實(shí)現(xiàn)。通過(guò)三個(gè)函數(shù),分別對(duì)Hanoi進(jìn)行遞歸、非遞歸和非遞歸規(guī)律實(shí)現(xiàn)。2013-05-05
詳解Java模擬棧的實(shí)現(xiàn)以及Stack類的介紹
棧是一種數(shù)據(jù)結(jié)構(gòu),它按照后進(jìn)先出的原則來(lái)存儲(chǔ)和訪問(wèn)數(shù)據(jù)。Stack是一個(gè)類,表示棧數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)。本文就來(lái)和大家介紹一下Java模擬棧的實(shí)現(xiàn)以及Stack類的使用,需要的可以參考一下2023-04-04
使用Eclipse創(chuàng)建Maven的Java WEB項(xiàng)目的兩種方式
本文詳細(xì)介紹了如何在JDK 1.8、Maven 3.6.3和Eclipse 2017版本下創(chuàng)建Java Web項(xiàng)目,包括選擇archetype方式、配置Tomcat、設(shè)置為Web3.1、配置Maven編譯級(jí)別、修復(fù)Eclipse提示的錯(cuò)誤、設(shè)置Maven源文件夾等步驟,需要的朋友可以參考下2024-11-11

