溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決

發(fā)布時間:2020-12-01 16:09:25 來源:億速云 閱讀:2874 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當中小編將會給大家?guī)碛嘘P(guān)利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

一. 問題還原

1. Controller代碼部分

Page<FixedAssetsEntity> pageForPlus = getPage();

Page<FixedAssetsEntity> fixedAssetsEntityPage = fixedAssetsService.selectPage(pageForPlus);

2.spring-mybatis.xml中的sqlSessionFactory配置

 <bean id="sqlSessionFactory"
   class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
  <!-- 配置數(shù)據(jù)源 -->
  <property name="dataSource" ref="dataSource" />
  <!-- 自動掃描 Xml 文件位置 -->
  <property name="mapperLocations" value="classpath*:mapping/**/*.xml" />
  <!-- 配置 Mybatis 配置文件(可無) -->
  <property name="configLocation" value="classpath:mybatis-config.xml" />
  <!-- 配置包別名,支持通配符 * 或者 ; 分割 -->
  <property name="typeAliasesPackage" value="com.syb.dto,com.syb.sys.entity" />
  <!-- 枚舉屬性配置掃描,支持通配符 * 或者 ; 分割 -->
  <!-- <property name="typeEnumsPackage" value="com.baomidou.springmvc.entity.*.enums"/> -->
  <!-- 以上配置和傳統(tǒng) Mybatis 一致 -->
  <!-- MP 全局配置注入 -->
  <property name="globalConfig" ref="globalConfig" />
 </bean>

打斷點查看fixedAssetsEntityPage,records條目正確,但是total和pages都是0

利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決

二. 解決

查閱官方文檔發(fā)現(xiàn),缺少了分頁插件的配置,在sqlSessionFactory中添加分頁插件,添加后為

<bean id="sqlSessionFactory"
   class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean">
  <!-- 配置數(shù)據(jù)源 -->
  <property name="dataSource" ref="dataSource" />
  <!-- 自動掃描 Xml 文件位置 -->
  <property name="mapperLocations" value="classpath*:mapping/**/*.xml" />
  <!-- 配置 Mybatis 配置文件(可無) -->
  <property name="configLocation" value="classpath:mybatis-config.xml" />
  <!-- 配置包別名,支持通配符 * 或者 ; 分割 -->
  <property name="typeAliasesPackage" value="com.syb.dto,com.syb.sys.entity" />
  <!-- 枚舉屬性配置掃描,支持通配符 * 或者 ; 分割 -->
  <!-- <property name="typeEnumsPackage" value="com.baomidou.springmvc.entity.*.enums"/> -->
  <!-- 以上配置和傳統(tǒng) Mybatis 一致 -->
  <!-- MP 全局配置注入 -->
  <property name="plugins">
   <array>
    <!-- 分頁插件配置 -->
    <bean id="paginationInterceptor" class="com.baomidou.mybatisplus.plugins.PaginationInterceptor">
     <property name="dialectType" value="mysql" />
    </bean>
   </array>
  </property>
  <property name="globalConfig" ref="globalConfig" />
 </bean>

運行程序,打斷點查看,total和page已經(jīng)正常顯示

補充知識:mybatisPlus分頁查詢多次查到相同數(shù)據(jù)的問題

一、問題描述

使用 mybatisPlus 3.1.0,在同一個方法內(nèi),多次調(diào)用同一個方法進行分頁查詢,每次查詢的分頁頁碼遞增,結(jié)果每次查到的數(shù)據(jù)都一樣。

二、相關(guān)知識:mybatis 一級緩存

mybatis存在緩存機制,查詢到的數(shù)據(jù)會納入緩存,同一sqlSession共享的叫一級緩存。默認情況下,mybatis會使用一級緩存

會取一級緩存的條件:

1、同一個 sqlSession

2、同一個 Mapper 方法

3、參數(shù)沒有發(fā)生變化

三、問題原因

mybatis 判斷是否需要使用一級緩存的代碼,早于 mybatisPlus 分頁插件攔截的代碼執(zhí)行(分頁代碼早一點執(zhí)行,才有機會將分頁參數(shù)也作為是否取緩存的依據(jù))

附圖:

利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決

利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決

四、解決辦法

在 DAO.xml 對應(yīng)的 select 標簽里,增加屬性 flushCache="true"

上述就是小編為大家分享的利用mybatis plus 進行分頁查詢時出現(xiàn)total與pages的值為零如何解決了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI