溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mybatis中的多重if條件判斷怎么用

發(fā)布時間:2022-03-11 11:39:14 來源:億速云 閱讀:1210 作者:iii 欄目:開發(fā)技術(shù)

這篇“mybatis中的多重if條件判斷怎么用”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“mybatis中的多重if條件判斷怎么用”文章吧。

mybatis 多重if 條件判斷

mybatis中的多重if條件判斷怎么用

要注意的是

當指定某種情況的時候,條件需要添加 toString() 方法

mybatis常用判斷語法(標簽)

作為java開發(fā),我們常用的判斷有if、switch語句,其實在MyBatis中也有對應的標簽,用于動態(tài)生成sql語句。

1. if判斷

<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)鍵字刪除;

2.choose判斷

<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è)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(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)容。

AI