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

MyBatisPlus 暫時(shí)分頁失效原因及問題解決

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

背景介紹

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

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

具體原因如下:

配置

分頁插件正確的配置應(yīng)該如下

    public PaginationInnerInterceptor paginationInnerInterceptor()
    {
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor();
        // 設(shè)置數(shù)據(jù)庫類型為mysql
        paginationInnerInterceptor.setDbType(DbType.MYSQL);
        // 設(shè)置最大單頁限制數(shù)量,默認(rèn) 500 條,-1 不受限制
        // 在mybatis-plus-boot-starter 3.4.3.1及以后需要注釋掉才能在設(shè)置pageSize<0時(shí)候成功暫時(shí)不分頁
        // 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就可以暫時(shí)不分頁
            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 且不限制返回值則不構(gòu)造分頁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及以后判斷條件多了一個(gè)限制,就是不能設(shè)置單頁最大限制(maxLimit)屬性值, 只有該值為null的前提下設(shè)置pageSize<0才能暫時(shí)不分頁成功?。?!

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

相關(guān)文章

  • Springboot整合junit過程解析

    Springboot整合junit過程解析

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

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

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

    Spring Cloud中使用Eureka的詳細(xì)過程

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

最新評(píng)論