您的位置:首頁技術文章
文章詳情頁

解決mybatis plus 分頁查詢有條數,total和pages都是零的問題

瀏覽:115日期:2023-10-21 10:46:18

一. 問題還原

1. Controller代碼部分

Page<FixedAssetsEntity> pageForPlus = getPage();

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

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

<bean class='com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean'> <!-- 配置數據源 --> <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'/> --> <!-- 以上配置和傳統 Mybatis 一致 --> <!-- MP 全局配置注入 --> <property name='globalConfig' ref='globalConfig' /> </bean>

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

解決mybatis plus 分頁查詢有條數,total和pages都是零的問題

二. 解決

查閱官方文檔發現,缺少了分頁插件的配置,在sqlSessionFactory中添加分頁插件,添加后為

<bean class='com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean'> <!-- 配置數據源 --> <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'/> --> <!-- 以上配置和傳統 Mybatis 一致 --> <!-- MP 全局配置注入 --> <property name='plugins'> <array> <!-- 分頁插件配置 --> <bean class='com.baomidou.mybatisplus.plugins.PaginationInterceptor'> <property name='dialectType' value='mysql' /> </bean> </array> </property> <property name='globalConfig' ref='globalConfig' /> </bean>

運行程序,打斷點查看,total和page已經正常顯示

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

一、問題描述

使用 mybatisPlus 3.1.0,在同一個方法內,多次調用同一個方法進行分頁查詢,每次查詢的分頁頁碼遞增,結果每次查到的數據都一樣。

二、相關知識:mybatis 一級緩存

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

會取一級緩存的條件:

1、同一個 sqlSession

2、同一個 Mapper 方法

3、參數沒有發生變化

三、問題原因

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

附圖:

解決mybatis plus 分頁查詢有條數,total和pages都是零的問題

解決mybatis plus 分頁查詢有條數,total和pages都是零的問題

四、解決辦法

在 DAO.xml 對應的 select 標簽里,增加屬性 flushCache='true'​

以上這篇解決mybatis plus 分頁查詢有條數,total和pages都是零的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Mybatis 數據庫
国产综合久久一区二区三区