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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Spring BeanFactory和FactoryBean區(qū)別解析
這篇文章主要介紹了Spring BeanFactory和FactoryBean區(qū)別解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-03-03
Java通過python命令執(zhí)行DataX任務的實例
今天小編就為大家分享一篇Java通過python命令執(zhí)行DataX任務的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-08-08
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的一些操作,例如截取N頁并生成新文件,轉(zhuǎn)圖片以及多個PDF合并,文中的示例代碼講解詳細,感興趣的可以了解下2025-01-01

