解決mybatis plus 分頁查詢有條數(shù),total和pages都是零的問題
一. 問題還原
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" /> <!-- 自動(dòng)掃描 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>
打斷點(diǎn)查看fixedAssetsEntityPage,records條目正確,但是total和pages都是0
二. 解決
查閱官方文檔發(fā)現(xiàn),缺少了分頁插件的配置,在sqlSessionFactory中添加分頁插件,添加后為
<bean id="sqlSessionFactory" class="com.baomidou.mybatisplus.spring.MybatisSqlSessionFactoryBean"> <!-- 配置數(shù)據(jù)源 --> <property name="dataSource" ref="dataSource" /> <!-- 自動(dòng)掃描 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>
運(yùn)行程序,打斷點(diǎn)查看,total和page已經(jīng)正常顯示
補(bǔ)充知識(shí):mybatisPlus分頁查詢多次查到相同數(shù)據(jù)的問題
一、問題描述
使用 mybatisPlus 3.1.0,在同一個(gè)方法內(nèi),多次調(diào)用同一個(gè)方法進(jìn)行分頁查詢,每次查詢的分頁頁碼遞增,結(jié)果每次查到的數(shù)據(jù)都一樣。
二、相關(guān)知識(shí):mybatis 一級(jí)緩存
mybatis存在緩存機(jī)制,查詢到的數(shù)據(jù)會(huì)納入緩存,同一sqlSession共享的叫一級(jí)緩存。默認(rèn)情況下,mybatis會(huì)使用一級(jí)緩存
會(huì)取一級(jí)緩存的條件:
1、同一個(gè) sqlSession
2、同一個(gè) Mapper 方法
3、參數(shù)沒有發(fā)生變化
三、問題原因
mybatis 判斷是否需要使用一級(jí)緩存的代碼,早于 mybatisPlus 分頁插件攔截的代碼執(zhí)行(分頁代碼早一點(diǎn)執(zhí)行,才有機(jī)會(huì)將分頁參數(shù)也作為是否取緩存的依據(jù))
附圖:
四、解決辦法
在 DAO.xml 對(duì)應(yīng)的 select 標(biāo)簽里,增加屬性 flushCache="true"
以上這篇解決mybatis plus 分頁查詢有條數(shù),total和pages都是零的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
java開啟遠(yuǎn)程debug竟有兩種參數(shù)(最新推薦)
這篇文章主要介紹了java開啟遠(yuǎn)程debug竟有兩種參數(shù),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07Mybatis Plus 自定義方法實(shí)現(xiàn)分頁功能的示例代碼
這篇文章主要介紹了Mybatis Plus 自定義方法實(shí)現(xiàn)分頁功能的示例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08Java數(shù)據(jù)結(jié)構(gòu)與算法之選擇排序(動(dòng)力節(jié)點(diǎn)java學(xué)院整理)
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)與算法之選擇排序的相關(guān)資料,本文通過代碼講解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下2017-04-04Spring boot2X負(fù)載均衡和反向代理實(shí)現(xiàn)過程解析
這篇文章主要介紹了Spring boot2X負(fù)載均衡和反向代理實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12深入解析JVM之內(nèi)存結(jié)構(gòu)及字符串常量池(推薦)
Java作為一種平臺(tái)無關(guān)性的語言,其主要依靠于Java虛擬機(jī)——JVM,接下來通過本文給大家介紹JVM之內(nèi)存結(jié)構(gòu)及字符串常量池的相關(guān)知識(shí),需要的朋友可以參考下2020-07-07SpringBoot使用Redisson實(shí)現(xiàn)分布式鎖(秒殺系統(tǒng))
這篇文章主要為大家詳細(xì)介紹了SpringBoot使用Redisson實(shí)現(xiàn)分布式鎖,秒殺系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-12-12