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

springboot集成PageHelper分頁失效的原因及解決

 更新時間:2023年10月06日 09:22:54   作者:aq_money  
項目啟動初期,在集成mybatis的分頁插件,自定義封裝了一個分頁的工具類,方便后期項目的擴展,結(jié)果無法分頁了,怎么設(shè)置搞都沒辦法正常分頁,所以本文將給大家介紹一下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;
  1. 分析問題
  2. 為什么會出現(xiàn)這樣的問題呢,在網(wǎng)上找了很久,但是沒有找到對應的解決方案。因為項目是springboot工程,項目管理方面跟spring是有差異的,就像昨天對ApplicationContextAware做封裝一樣,需要使用@Component管理bean是一個道理??赡苁莔aven依賴的問題導致的我的分頁插件失效了。一開始使用的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版本不兼容可能導致問題。請確保你正在使用兼容的版本。

  • 注意pom.xml導入的依賴:應該是spring版本的而不是其獨立的版本

  • SQL查詢是否正確: 最后,請確保你的SQL查詢在數(shù)據(jù)庫中是有效的,且返回了正確的結(jié)果。你可以在數(shù)據(jù)庫中手動運行查詢來驗證它是否按預期工作。

  • 只有緊跟著PageHelper.startPage()的sql語句才被pagehelper起作用。(注意,經(jīng)過再次驗證,這里不是扯淡,其原理可能是
    “PageHelper.startPage(pageNum,pageSize)”在使用的時候啟動了一個線程,致使了其能達到這個效果”)

以上就是springboot集成PageHelper分頁失效的原因及解決的詳細內(nèi)容,更多關(guān)于springboot集成PageHelper的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論