MyBatis mapper.xml中使用靜態常量或者靜態方法


使用MyBatis技術,書寫mapper.xml時,如果在其中的ognl表達式或者sql中直接使用一些數字或者字符串的話,會造成難以維護的問題。在Java編碼中,我們通常會把這些數字或者字符串定義在常量類或者接口中,如果在mapper.xml中也可以使用這些常量就比較好了。還好MybBatis是支持這樣的需求的。

包名:com.test.util
類名:DateUtil
靜態變量:CURRENT_YEAR
靜態方法:sLeapYear

靜態方法

package com.test.util;

public class DateUtil {

    public static final String CURRENT_YEAR = "id";

    public static String sLeapYear(String who) {
        return who;
    }
}

mapper.xml

// 引用靜態常量
<select id="test">
        select *
        from user
        where port = ${@com.test.util.DateUtil@CURRENT_YEAR}
</select>

// 引用靜態方法
<select id="test">
        select *
        from user
        where port = ${@com.test.util.DateUtil@sLeapYear()}
</select>

// 當我們使用<if test=""></if>判斷標簽時,不用使用${}進行拼接,直接使用@加上路徑就可作為條件判斷使用
<select id="test">
        select *
        from user
        <if test = "@com.test.util.DateUtil@sLeapYear()">
           where port = 1 
        </if>
</select>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM