springboot集成PageHelper分頁失效的原因及解決
前言
項(xiàng)目啟動(dòng)初期,在集成mybatis的分頁插件,自定義封裝了一個(gè)分頁的工具類,方便后期項(xiàng)目的擴(kuò)展。部分的代碼如下:
/** * 分頁查詢 * 進(jìn)行count計(jì)算 * * @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)問題
- 找了很久,一直不明白為什么會(huì)無法進(jìn)行分頁。對(duì)PageHelper進(jìn)行了封裝,然后直接調(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;
- 分析問題
- 為什么會(huì)出現(xiàn)這樣的問題呢,在網(wǎng)上找了很久,但是沒有找到對(duì)應(yīng)的解決方案。因?yàn)轫?xiàng)目是springboot工程,項(xiàng)目管理方面跟spring是有差異的,就像昨天對(duì)ApplicationContextAware做封裝一樣,需要使用@Component管理bean是一個(gè)道理??赡苁莔aven依賴的問題導(dǎo)致的我的分頁插件失效了。一開始使用的maven依賴
- 解決問題
- 為了驗(yàn)證我的猜想,我先把代碼單獨(dú)的拎出來打斷點(diǎn)跑一下。代碼如下:
PageHelper.startPage(1,5); List<SysUserDO> sysUserDOS = sysUserDao.get(); PageInfo<SysUserDO> sysUserDOPageInfo = new PageInfo<>(sysUserDOS);
- 結(jié)果正如所料,打了斷點(diǎn)看代碼,并沒有成功的進(jìn)行分頁。設(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>
- 這次打斷點(diǎn)一看,分頁成功了。
總結(jié)
做人做到底,送佛送到西。今天踩了一個(gè)坑。對(duì)PageHelper 分頁失效的問題進(jìn)行一下匯總。
PageHelper未正確配置: 請(qǐng)確保你的PageHelper配置在Spring Boot的配置文件中已經(jīng)生效。你的配置看起來正確,但需要確保配置文件的位置和名稱與Spring Boot的要求一致(通常是application.yml或application.properties)。
PageHelper版本問題: 有時(shí)候,PageHelper的版本與MyBatis或Spring Boot版本不兼容可能導(dǎo)致問題。請(qǐng)確保你正在使用兼容的版本。
注意pom.xml導(dǎo)入的依賴:應(yīng)該是spring版本的而不是其獨(dú)立的版本
SQL查詢是否正確: 最后,請(qǐng)確保你的SQL查詢?cè)跀?shù)據(jù)庫中是有效的,且返回了正確的結(jié)果。你可以在數(shù)據(jù)庫中手動(dòng)運(yùn)行查詢來驗(yàn)證它是否按預(yù)期工作。
只有緊跟著PageHelper.startPage()的sql語句才被pagehelper起作用。(注意,經(jīng)過再次驗(yàn)證,這里不是扯淡,其原理可能是
“PageHelper.startPage(pageNum,pageSize)”在使用的時(shí)候啟動(dòng)了一個(gè)線程,致使了其能達(dá)到這個(gè)效果”)
以上就是springboot集成PageHelper分頁失效的原因及解決的詳細(xì)內(nèi)容,更多關(guān)于springboot集成PageHelper的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Spring?Boot?ORM?框架JPA使用與連接池?Hikari詳解
這篇文章主要介紹了SpringBoot?ORM框架JPA與連接池Hikari,主要就是介紹JPA?的使用姿勢,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08Spring?Session(分布式Session共享)實(shí)現(xiàn)示例
這篇文章主要介紹了Spring?Session(分布式Session共享)實(shí)現(xiàn)示例,文章內(nèi)容詳細(xì),需要的朋友可以參考下2023-01-01Java class文件格式之特殊字符串_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
特殊字符串出現(xiàn)在class文件中的常量池中,本著循序漸進(jìn)和減少跨度的原則, 首先把class文件中的特殊字符串做一個(gè)詳細(xì)的介紹, 然后再回過頭來繼續(xù)講解常量池,對(duì)java class 文件格式相關(guān)知識(shí)感興趣的的朋友一起學(xué)習(xí)吧2017-06-06Spring boot項(xiàng)目redisTemplate實(shí)現(xiàn)輕量級(jí)消息隊(duì)列的方法
這篇文章主要給大家介紹了關(guān)于Spring boot項(xiàng)目redisTemplate實(shí)現(xiàn)輕量級(jí)消息隊(duì)列的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring boot具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04基于Java將Excel科學(xué)計(jì)數(shù)法解析成數(shù)字
這篇文章主要介紹了基于Java將Excel科學(xué)計(jì)數(shù)法解析成數(shù)字,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下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()方法的用法(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01Java線程的調(diào)度與優(yōu)先級(jí)詳解
這篇文章主要為大家詳細(xì)介紹了Java線程的調(diào)度與優(yōu)先級(jí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03Java項(xiàng)目之java+springboot+ssm實(shí)現(xiàn)理財(cái)管理系統(tǒng)設(shè)計(jì)
這篇文章主要介紹了Java項(xiàng)目java+springboot+ssm實(shí)現(xiàn)理財(cái)管理系統(tǒng)設(shè)計(jì),使用了當(dāng)前較為流行的spring boot,spring,spring mvc,mybatis,shiro框架分頁處理使用了pagehelper進(jìn)行操作,需要的朋友可以參考一下2022-03-03