您好,登錄后才能下訂單哦!
這篇“mybatis中的多重if條件判斷怎么用”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“mybatis中的多重if條件判斷怎么用”文章吧。
當指定某種情況的時候,條件需要添加 toString() 方法
作為java開發(fā),我們常用的判斷有if、switch語句,其實在MyBatis中也有對應的標簽,用于動態(tài)生成sql語句。
<where> <if test="null != statusCode and 0 != statusCode"> AND b.STATUS_CODE = #{statusCode, jdbcType=VARCHAR} </if> </where>
一般來說,很多程序猿朋友會在<if>標簽前增加WHERE 1=1語句,但其實只需要像上面代碼中增加<where>標簽包裹所有<if>語句,<if>內(nèi)語句前面都有and或者or關(guān)鍵字就行:
MyBatis會自動判斷所有條件不滿足時,不添加where語句;
如果有多判斷語句,并且滿足一個條件以上時,會把第一條滿足的(如果第一條有and或者or關(guān)鍵字時)and或者or關(guān)鍵字刪除;
<choose> <when test="5 == queryType"> CASE WHEN statusCode IN (1,6) THEN 1 ELSE 2 END,createTime DESC </when> <when test="1 != queryType and 9 != queryType"> createTime DESC </when> <otherwise> <choose> <when test="null == orderType or 1 == orderType"> auditTime </when> <when test="2 == orderType"> downloadCount </when> <when test="3 == orderType"> browseCount </when> <otherwise> is666Count </otherwise> </choose> <if test="null == orderMode or 1 == orderMode"> DESC </if> </otherwise> </choose>
上面的代碼使用了標簽嵌套特性,用于復雜條件判斷。
choose判斷跟if else語句作用相同,起到根據(jù)條件執(zhí)行不同分支邏輯的作用。
而otherwise跟多個if else中最后一個else的作用相同,在以上條件都不滿足時,執(zhí)行otherwise中的邏輯。
以上就是關(guān)于“mybatis中的多重if條件判斷怎么用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。