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

MyBatisPlus 暫時分頁失效原因及問題解決

 更新時間:2025年07月29日 09:49:36   作者:剛貼瞎  
MybatisPlus升級后分頁失效,因新版本PaginationInnerInterceptor中新增maxLimit限制,下面就來介紹MyBatisPlus 暫時分頁失效原因及問題解決,感興趣的可以了解一下

背景介紹

在更新完MybatisPlus版本后暫時分頁功能失效。

記得原來版本是可以成功的,可以在傳參時候?qū)ageSize設置<0可以成功的暫時不分頁,結果升級完MybatisPlus版本后失效了,將pageSize<0的值拼接到了limit條件中,直接導致報錯。在一步一步的排查中發(fā)現(xiàn)是源碼中作了調(diào)整,-_-||

具體原因如下:

配置

分頁插件正確的配置應該如下

    public PaginationInnerInterceptor paginationInnerInterceptor()
    {
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
        // 設置數(shù)據(jù)庫類型為mysql
        paginationInnerInterceptor.setDbType(DbType.MYSQL);
        // 設置最大單頁限制數(shù)量,默認 500 條,-1 不受限制
        // 在mybatis-plus-boot-starter 3.4.3.1及以后需要注釋掉才能在設置pageSize<0時候成功暫時不分頁
        // paginationInnerInterceptor.setMaxLimit(-1L);
        return paginationInnerInterceptor;
    }

源碼分析

3.4.3以及以前的版本

在 PaginationInnerInterceptor 中的 beforeQuery 方法

    public void beforeQuery(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) throws SQLException {
            
            ......
            // 此處只有判斷pageSize的值,只要小于0就可以暫時不分頁
            if (page.getSize() < 0L) {
                if (addOrdered) {
                    PluginUtils.mpBoundSql(boundSql).sql(buildSql);
                }

            } else {
               ......
            }
        
    }

3.4.3.1及以后版本

在 PaginationInnerInterceptor 中的 beforeQuery 方法

    public void beforeQuery(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {
        ......

        // size 小于 0 且不限制返回值則不構造分頁sql
        Long _limit = page.maxLimit() != null ? page.maxLimit() : maxLimit;
        if (page.getSize() < 0 && null == _limit) {
            if (addOrdered) {
                PluginUtils.mpBoundSql(boundSql).sql(buildSql);
            }
            return;
        }

        ......
    }

可以看出在3.4.3.1及以后判斷條件多了一個限制,就是不能設置單頁最大限制(maxLimit)屬性值, 只有該值為null的前提下設置pageSize<0才能暫時不分頁成功?。?!

到此這篇關于MyBatisPlus 暫時分頁失效原因及問題解決的文章就介紹到這了,更多相關MyBatisPlus 暫時分頁失效內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Springboot整合junit過程解析

    Springboot整合junit過程解析

    這篇文章主要介紹了Springboot整合junit過程解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-05-05
  • Spring BeanFactory和FactoryBean區(qū)別解析

    Spring BeanFactory和FactoryBean區(qū)別解析

    這篇文章主要介紹了Spring BeanFactory和FactoryBean區(qū)別解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-03-03
  • Spring Cloud中使用Eureka的詳細過程

    Spring Cloud中使用Eureka的詳細過程

    Eureka 是 Netflix 開源的一個服務發(fā)現(xiàn)組件,它在微服務架構中扮演著重要的角色,這篇文章主要介紹了Spring Cloud中如何使用Eureka,需要的朋友可以參考下
    2024-07-07
  • java鏈表的頭插法和尾插法詳解

    java鏈表的頭插法和尾插法詳解

    本文介紹了鏈表的基本概念,包括節(jié)點類Listnode和鏈表類Linklist,頭插法和尾插法是兩種常見的插入節(jié)點的方法,分別通過頭指針和游標來實現(xiàn),通過示例代碼和測試,展示了鏈表的創(chuàng)建和操作過程
    2024-12-12
  • Java通過python命令執(zhí)行DataX任務的實例

    Java通過python命令執(zhí)行DataX任務的實例

    今天小編就為大家分享一篇Java通過python命令執(zhí)行DataX任務的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Spring 實現(xiàn)自定義監(jiān)聽器案例

    Spring 實現(xiàn)自定義監(jiān)聽器案例

    這篇文章主要介紹了Spring 實現(xiàn)自定義監(jiān)聽器案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • java 可重啟線程及線程池類的設計(詳解)

    java 可重啟線程及線程池類的設計(詳解)

    下面小編就為大家?guī)硪黄猨ava 可重啟線程及線程池類的設計(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • Java語言實現(xiàn)簡單FTP軟件 FTP連接管理模塊實現(xiàn)(8)

    Java語言實現(xiàn)簡單FTP軟件 FTP連接管理模塊實現(xiàn)(8)

    這篇文章主要為大家詳細介紹了Java語言實現(xiàn)簡單FTP軟件,F(xiàn)TP連接管理模塊的實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • JAVA PDF操作之實現(xiàn)截取N頁和多個PDF合并

    JAVA PDF操作之實現(xiàn)截取N頁和多個PDF合并

    這篇文章主要為大家詳細介紹了java關于PDF的一些操作,例如截取N頁并生成新文件,轉(zhuǎn)圖片以及多個PDF合并,文中的示例代碼講解詳細,感興趣的可以了解下
    2025-01-01
  • java進行遠程部署與調(diào)試及原理詳解

    java進行遠程部署與調(diào)試及原理詳解

    這篇文章主要介紹了java進行遠程部署與調(diào)試及原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-12-12

最新評論