springboot集成PageHelper分頁失效的原因及解決
前言
項目啟動初期,在集成mybatis的分頁插件,自定義封裝了一個分頁的工具類,方便后期項目的擴展。部分的代碼如下:
/** * 分頁查詢 * 進行count計算 * * @param pageNum 頁數(shù) * @param pageSize 每頁數(shù)量 * @param supplier 查詢操作 * @return */ public static <T> PageInfo<T> pageQueryWithCount(int pageNum, int pageSize, Supplier<List<T>> supplier) { if (pageNum < 1) pageNum = getDefaultPageNum(); if (pageSize < 1) pageSize = getDefaultPageSize(); try { Page<T> page = PageHelper.startPage(pageNum, pageSize, true); supplier.get(); return new PageInfo<T>(page); } finally { PageHelper.clearPage(); } }
問題
結(jié)果懵逼了,無法分頁了。怎么設(shè)置搞都沒辦法正常分頁,把我腦子搞暈乎了哎呀。
分析
- 發(fā)現(xiàn)問題
- 找了很久,一直不明白為什么會無法進行分頁。對PageHelper進行了封裝,然后直接調(diào)用的工具類的代碼。我的代碼如下:
PageInfo<SysUserDO> sysUserDOPageInfo = PageUtils.pageQueryWithCount(pageNum, pageSize, () -> sysUserDao.get() ); GenericPageRspBO genericPageRspBO = new GenericPageRspBO(); genericPageRspBO.setTotal(sysUserDOPageInfo.getTotal()); genericPageRspBO.setResultList(BeanCopyUtils.deepCopyBeanList(sysUserDOPageInfo.getList(), SysUserBO.class)); return genericPageRspBO;
- 分析問題
- 為什么會出現(xiàn)這樣的問題呢,在網(wǎng)上找了很久,但是沒有找到對應(yīng)的解決方案。因為項目是springboot工程,項目管理方面跟spring是有差異的,就像昨天對ApplicationContextAware做封裝一樣,需要使用@Component管理bean是一個道理??赡苁莔aven依賴的問題導(dǎo)致的我的分頁插件失效了。一開始使用的maven依賴
- 解決問題
- 為了驗證我的猜想,我先把代碼單獨的拎出來打斷點跑一下。代碼如下:
PageHelper.startPage(1,5); List<SysUserDO> sysUserDOS = sysUserDao.get(); PageInfo<SysUserDO> sysUserDOPageInfo = new PageInfo<>(sysUserDOS);
- 結(jié)果正如所料,打了斷點看代碼,并沒有成功的進行分頁。設(shè)置了分頁參數(shù),但是查詢了12條數(shù)據(jù)。
- 果然,把代碼抽出來看一下就知道究竟是我的工具類封裝有問題還是分頁插件的問題。找到了問題接下來就順暢很多了。我先替換了maven的依賴,使用springboot工程版本。maven依賴如下:
<dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>1.4.1</version> </dependency>
- 這次打斷點一看,分頁成功了。
總結(jié)
做人做到底,送佛送到西。今天踩了一個坑。對PageHelper 分頁失效的問題進行一下匯總。
PageHelper未正確配置: 請確保你的PageHelper配置在Spring Boot的配置文件中已經(jīng)生效。你的配置看起來正確,但需要確保配置文件的位置和名稱與Spring Boot的要求一致(通常是application.yml或application.properties)。
PageHelper版本問題: 有時候,PageHelper的版本與MyBatis或Spring Boot版本不兼容可能導(dǎo)致問題。請確保你正在使用兼容的版本。
注意pom.xml導(dǎo)入的依賴:應(yīng)該是spring版本的而不是其獨立的版本
SQL查詢是否正確: 最后,請確保你的SQL查詢在數(shù)據(jù)庫中是有效的,且返回了正確的結(jié)果。你可以在數(shù)據(jù)庫中手動運行查詢來驗證它是否按預(yù)期工作。
只有緊跟著PageHelper.startPage()的sql語句才被pagehelper起作用。(注意,經(jīng)過再次驗證,這里不是扯淡,其原理可能是
“PageHelper.startPage(pageNum,pageSize)”在使用的時候啟動了一個線程,致使了其能達到這個效果”)
以上就是springboot集成PageHelper分頁失效的原因及解決的詳細內(nèi)容,更多關(guān)于springboot集成PageHelper的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Spring?Boot?ORM?框架JPA使用與連接池?Hikari詳解
這篇文章主要介紹了SpringBoot?ORM框架JPA與連接池Hikari,主要就是介紹JPA?的使用姿勢,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-08-08Spring?Session(分布式Session共享)實現(xiàn)示例
這篇文章主要介紹了Spring?Session(分布式Session共享)實現(xiàn)示例,文章內(nèi)容詳細,需要的朋友可以參考下2023-01-01Java class文件格式之特殊字符串_動力節(jié)點Java學(xué)院整理
特殊字符串出現(xiàn)在class文件中的常量池中,本著循序漸進和減少跨度的原則, 首先把class文件中的特殊字符串做一個詳細的介紹, 然后再回過頭來繼續(xù)講解常量池,對java class 文件格式相關(guān)知識感興趣的的朋友一起學(xué)習(xí)吧2017-06-06Spring boot項目redisTemplate實現(xiàn)輕量級消息隊列的方法
這篇文章主要給大家介紹了關(guān)于Spring boot項目redisTemplate實現(xiàn)輕量級消息隊列的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Spring boot具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04基于Java將Excel科學(xué)計數(shù)法解析成數(shù)字
這篇文章主要介紹了基于Java將Excel科學(xué)計數(shù)法解析成數(shù)字,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-09-09Caused?by:?java.lang.NumberFormatException:?For?input?s
這篇文章主要介紹了Caused?by:?java.lang.NumberFormatException:?For?input?string:?“port“,本文給大家分享完美解決方法,需要的朋友可以參考下2023-01-01淺談java Iterator.remove()方法的用法(詳解)
下面小編就為大家?guī)硪黄獪\談java Iterator.remove()方法的用法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01Java項目之java+springboot+ssm實現(xiàn)理財管理系統(tǒng)設(shè)計
這篇文章主要介紹了Java項目java+springboot+ssm實現(xiàn)理財管理系統(tǒng)設(shè)計,使用了當前較為流行的spring boot,spring,spring mvc,mybatis,shiro框架分頁處理使用了pagehelper進行操作,需要的朋友可以參考一下2022-03-03