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

mybatis mapper.xml 區(qū)間查詢條件詳解

 更新時間:2021年09月30日 11:34:36   作者:傾-盡  
這篇文章主要介紹了mybatis mapper.xml 區(qū)間查詢條件詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

mybatis mapper.xml 區(qū)間查詢條件

對 null 和 ” 分開進(jìn)行判斷

<select id="selectByExample" resultMap="BaseResultMap" parameterType="com.test.entity.TestQuery">
SELECT 
    *
    FROM
    test s
    WHERE 1=1

    <!-- 創(chuàng)建時間 -->
    <if test="createTime!=null and createTime!=''">
        AND s.create_time = #{createTime,jdbcType=TIMESTAMP}
    </if>
    <!-- 開始創(chuàng)建時間,結(jié)束創(chuàng)建時間都不為空 -->
    <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime!=null and endCreateTime!=''">
        AND s.create_time &gt;= #{beginCreateTime,jdbcType=TIMESTAMP}
        AND s.create_time &lt;= #{endCreateTime,jdbcType=TIMESTAMP}
    </if>
    <!-- 開始不為空,結(jié)束為空 null -->
    <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime==null">
        AND s.create_time &gt;= #{beginCreateTime,jdbcType=TIMESTAMP}
    </if>
    <!-- 開始不為空,結(jié)束為空 '' -->
    <if test="beginCreateTime!=null and beginCreateTime!='' and endCreateTime==''">
        AND s.create_time &gt;= #{beginCreateTime,jdbcType=TIMESTAMP}
    </if>
    <!-- 開始為空 null,結(jié)束不為空 -->
    <if test="beginCreateTime==null  and endCreateTime!=null and endCreateTime!=''">
        AND s.create_time &lt;= #{endCreateTime,jdbcType=TIMESTAMP}
    </if>
    <!-- 開始為空 '',結(jié)束不為空 -->
    <if test="beginCreateTime==''  and endCreateTime!=null and endCreateTime!=''">
        AND s.create_time &lt;= #{endCreateTime,jdbcType=TIMESTAMP}
    </if>

</select>

tk mybatis通用mapper,復(fù)雜and or條件查詢

需求:where查詢,需要支持(a or b or c) and d

也就是a、b、c三個條件是或的關(guān)系,然后再與d相與。

嘗試后,可以通過以下方式處理:

方式1:Weekend語法

     Weekend<User> weekend = new Weekend<>(User.class);
        //關(guān)鍵字查詢部分
        String keyword = pageReq.getKeyword();
        WeekendCriteria<User, Object> keywordCriteria = weekend.weekendCriteria();
        if (StringUtils.isNotEmpty(keyword)) {
            keywordCriteria.orLike(User::getUserName, keyword).orLike(User::getPoliceNo, keyword).orLike(User::getRealName, keyword);
        //此處不需要再用下面這一句了,不然上面這個條件組合會重復(fù)一次
            //weekend.and(keywordCriteria)
        }
        //部門查詢部分
        Example example = new Example(User.class);
        Example.Criteria criteria = example.createCriteria();
        criteria.andEqualTo("departmentId", departmentId);
        weekend.and(criteria);

        PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize());
        List<User> users = userMapper.selectByExample(weekend);

ps:上面,其中Weekend是高版本的通用mapper版本才有,而且需要java8語法支持。

方式2:通用example語法

        Example e = new Example(User.class);
        Example.Criteria c = e.createCriteria();

        //關(guān)鍵字查詢部分
        String keyword = pageReq.getKeyword();
        if (StringUtils.isNotEmpty(keyword)) {
            c.orEqualTo("userName", keyword).orEqualTo("policeNo",keyword).orEqualTo("realName",keyword);
        }
        //部門查詢部門
        Example.Criteria criteria = e.createCriteria();
        criteria.andEqualTo("departmentId", departmentId);
        e.and(criteria);

        PageHelper.startPage(pageReq.getPageIndex(), pageReq.getPageSize());
        List<User> users = userMapper.selectByExample(e);

執(zhí)行的sql為:

WHERE (
  user_name = ? 
  OR police_no = ? 
  OR real_name = ?
) 
AND (department_id = ?)

總結(jié)下來,就是,

每個條件組合(a/b/c) (d)各自創(chuàng)建自己的cirteria,再用and或者or方法去連接

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

相關(guān)文章

  • VSCode搭建Java開發(fā)環(huán)境的超詳細(xì)步驟

    VSCode搭建Java開發(fā)環(huán)境的超詳細(xì)步驟

    VSCode是一款多平臺的源代碼編輯器,支持多種編程語言,它輕量級、功能強(qiáng)大,通過豐富的插件生態(tài)系統(tǒng)可以支持更多語言和運行時,如C++、C#、Java、Python等,這篇文章主要介紹了VSCode搭建Java開發(fā)環(huán)境的超詳細(xì)步驟,需要的朋友可以參考下
    2024-10-10
  • mybatis-plus配置攔截器實現(xiàn)sql完整打印的代碼設(shè)計

    mybatis-plus配置攔截器實現(xiàn)sql完整打印的代碼設(shè)計

    在使用mybatis-plus(mybatis)的時候,往往需要打印完整的sql語句,然而輸出的日志不是很理想,因為sql語句中的關(guān)鍵字段信息都是用?來代替的,所以本文分享了一下自己寫了一個攔截器實現(xiàn)了sql完整的打印,需要的朋友可以參考下
    2024-06-06
  • Java初級必看的數(shù)據(jù)類型與常量變量知識點

    Java初級必看的數(shù)據(jù)類型與常量變量知識點

    這篇文章主要給大家介紹了關(guān)于Java初級必看的數(shù)據(jù)類型與常量變量知識點的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • Java中的Runnable,Callable,F(xiàn)uture,F(xiàn)utureTask的比較

    Java中的Runnable,Callable,F(xiàn)uture,F(xiàn)utureTask的比較

    這篇文章主要介紹了Java中的Runnable,Callable,F(xiàn)uture,F(xiàn)utureTask的比較的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • MyBatisPlus PaginationInterceptor分頁插件的使用詳解

    MyBatisPlus PaginationInterceptor分頁插件的使用詳解

    這篇文章主要介紹了MyBatisPlus PaginationInterceptor分頁插件的使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • java發(fā)送內(nèi)嵌圖片郵件

    java發(fā)送內(nèi)嵌圖片郵件

    這篇文章主要介紹了java發(fā)送內(nèi)嵌圖片郵件,在博客系統(tǒng)中需要郵件服務(wù)的功能,僅僅是發(fā)送文本內(nèi)容,現(xiàn)在嘗試一下發(fā)送內(nèi)嵌圖片郵件,感興趣的小伙伴們可以參考一下
    2016-01-01
  • Spring Boot 整合 TKMybatis 二次簡化持久層代碼的實現(xiàn)

    Spring Boot 整合 TKMybatis 二次簡化持久層代碼的實現(xiàn)

    這篇文章主要介紹了Spring Boot 整合 TKMybatis 二次簡化持久層代碼的實現(xiàn),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • Java?EventBus手把手帶你實現(xiàn)

    Java?EventBus手把手帶你實現(xiàn)

    EventBus是Guava的事件處理機(jī)制,是設(shè)計模式中觀察者模式(生產(chǎn)/消費者編程模型)的優(yōu)雅實現(xiàn)。本文就來和大家聊聊EventBus的使用,需要的可以參考一下
    2023-01-01
  • 詳解SpringBoot中如何使用Reactor模型

    詳解SpringBoot中如何使用Reactor模型

    Reactor模型主要提供了一種在Java虛擬機(jī)上構(gòu)建非阻塞應(yīng)用的方式,這種方式使用了響應(yīng)式編程原理,通過響應(yīng)式流標(biāo)準(zhǔn)來實現(xiàn),下面我們就來看看它在SpringBoot中是如何使用的吧
    2024-04-04
  • java工程師進(jìn)階之MyBatis延遲加載的使用

    java工程師進(jìn)階之MyBatis延遲加載的使用

    本文是java工程師進(jìn)階篇,主要介紹了java應(yīng)用開發(fā)中MyBatis延遲加載及如何使用,有需要的朋友 可以借鑒參考下,希望能夠有所幫助
    2021-09-09

最新評論