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)文章
Spring BeanFactory和FactoryBean區(qū)別解析
這篇文章主要介紹了Spring BeanFactory和FactoryBean區(qū)別解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-03-03
Spring Cloud中使用Eureka的詳細(xì)過程
Eureka 是 Netflix 開源的一個(gè)服務(wù)發(fā)現(xiàn)組件,它在微服務(wù)架構(gòu)中扮演著重要的角色,這篇文章主要介紹了Spring Cloud中如何使用Eureka,需要的朋友可以參考下2024-07-07
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)聽器案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01
java 可重啟線程及線程池類的設(shè)計(jì)(詳解)
下面小編就為大家?guī)硪黄猨ava 可重啟線程及線程池類的設(shè)計(jì)(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01
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合并
這篇文章主要為大家詳細(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)試及原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12

