Mybatis-plus原生pages分頁(yè)未生效的解決方案
前言
前端小伙伴今天問(wèn)我們后端同學(xué),說(shuō)他寫(xiě)得列表有問(wèn)題,分頁(yè)數(shù)據(jù)沒(méi)有成功,將所有數(shù)據(jù)都返回給前端了!
后端同學(xué)有些懵逼的說(shuō),我已經(jīng)使用了service的pages接口來(lái)查詢(xún)的列表,為什么失敗了呢?
各位小伙伴,你們知道怎么解決這個(gè)問(wèn)題嗎?先考慮一下。
原因
1、Mybatis Plus版本的問(wèn)題
當(dāng)我們使用的是較舊的版本,可能存在分頁(yè)失效的問(wèn)題。
解決辦法:升級(jí)到最新版本。
2、Mapper.xml文件中SQL語(yǔ)句格式問(wèn)題
在Mapper.xml中書(shū)寫(xiě)SQL語(yǔ)句時(shí),當(dāng)格式錯(cuò)誤了,就會(huì)導(dǎo)致分頁(yè)失效。
正確的格式:在最后加上limit #{offset}, #{pageSize}
#{offset}:偏移量;
#{pageSize}:每頁(yè)顯示的數(shù)量。
3、Mybatis Plus默認(rèn)分頁(yè)攔截器問(wèn)題
默認(rèn)情況下,Mybatis Plus自帶了一個(gè)分頁(yè)插件com.baomidou.mybatisplus.plugins.PaginationInterceptor。但是,有時(shí)候在進(jìn)行復(fù)雜查詢(xún)時(shí),這個(gè)分頁(yè)插件可能會(huì)失效,導(dǎo)致分頁(yè)查詢(xún)不到數(shù)據(jù)。
4、分頁(yè)參數(shù)傳參問(wèn)題
如果使用的是分頁(yè)查詢(xún)方法,那么在調(diào)用方法時(shí)就要傳入Page對(duì)象,而且必須在此前調(diào)用setRecordsTotal方法設(shè)置總記錄數(shù)。如果不設(shè)置總記錄數(shù),則分頁(yè)插件無(wú)法工作。
5、分頁(yè)配置的問(wèn)題
不同版本的mybatis-plus需要的分頁(yè)配置是不同的,是分水嶺版本為3.4.0
在它之后的版本開(kāi)始將原有的PaginationInterceptor 標(biāo)記為過(guò)時(shí),需要換成MybatisPlusInterceptor
解決方案
上面我們列出了5個(gè)導(dǎo)致分頁(yè)結(jié)果失敗的原因,接下來(lái)我們看看如何解決呢?分別一一對(duì)應(yīng)來(lái)看。
1、升級(jí)對(duì)應(yīng)的Mybatis-plus版本
如果我們使用的舊版本的Mybatis-plus,則可以升級(jí)為新版的。
在pom文件里面更新
<dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.3</version> </dependency>
2、分頁(yè)插件配置問(wèn)題
這個(gè)可以按照上面所說(shuō)的在Mapper.xml文件中調(diào)整
<select id="selectForPage" resultMap="BaseResultMap"> select * from tb_user <where> 1 = 1 </where> limit #{offset}, #{pageSize} </select>
配置Mybatis-plus分頁(yè)插件,可以在application.yml文件中加入如下配置:
mybatis-plus: configuration: # 分頁(yè)插件,一般不用修改 page-params: pageNum=1;pageSize=10;count=countSql
3、自定義分頁(yè)攔截器
Mybatis-plus提供了自定義分頁(yè)攔截器的功能,可以根據(jù)我們自己的業(yè)務(wù)進(jìn)行自定義。自定義分頁(yè)攔截器需要繼承com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor類(lèi),然后在實(shí)現(xiàn)intercept方法,在該方法中來(lái)處理我們具體的分頁(yè)邏輯。
例如:可以根據(jù)前端傳入的分頁(yè)參數(shù)進(jìn)行分頁(yè),而不是使用默認(rèn)的分頁(yè)參數(shù)。具體代碼示例如下:
public class CustomPaginationInterceptor extends PaginationInterceptor { @Override public Page SqlParserInterceptor(MappedStatement ms, Page page) { // 獲取前端傳入的分頁(yè)參數(shù) Integer pageNum = (Integer) page.get("pageNo"); Integer pageSize = (Integer) page.get("pageSize"); // 處理分頁(yè)邏輯 int offset = (pageNum - 1) * pageSize; return super.SqlParserInterceptor(ms, new Page(offset, pageSize)); } }
4、正確的參數(shù)
假如在調(diào)用分頁(yè)查詢(xún)方法的時(shí)候沒(méi)有傳入Page對(duì)象或者是沒(méi)有調(diào)用setRecordsTotal方法設(shè)置總條數(shù),則分頁(yè)查詢(xún)不到數(shù)據(jù)??梢圆捎靡韵路绞秸_傳參,具體代碼如下:
// 分頁(yè)查詢(xún)方法 IPage<Test> pageTest = new Page<>(pageNo, pageSize); // 設(shè)置總記錄數(shù) pageTest .setRecordsTotal(testMapper.selectCount(null)); // 查詢(xún) IPage<Test> pageResult = testMapper.selectPage(pageTest , null);
5、不同版本的配置文件
接下來(lái)我們看看不同版本的配置文件具體如何實(shí)現(xiàn)
3.4.0之前版本
在啟動(dòng)類(lèi)中添加Bean,配置類(lèi)代碼如下:
/** Mybatis plus 分頁(yè)插件 **/ @Bean public PaginationInterceptor paginationInterceptor() { PaginationInterceptor paginationInterceptor = new PaginationInterceptor(); // 設(shè)置請(qǐng)求的頁(yè)面大于最大頁(yè)后操作, true調(diào)回到首頁(yè),false 繼續(xù)請(qǐng)求 默認(rèn)false // paginationInterceptor.setOverflow(false); // 設(shè)置最大單頁(yè)限制數(shù)量,默認(rèn) 500 條,-1 不受限制 paginationInterceptor.setLimit(-1); return paginationInterceptor; }
3.4.0之后版本
配置類(lèi)代碼如下
package com.cafeteria.reservation.admin.config; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class MyBatisConfig { @Bean public MybatisPlusInterceptor paginationInterceptor() { MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor(); //這是分頁(yè)攔截器 PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(); paginationInnerInterceptor.setOverflow(false); paginationInnerInterceptor.setMaxLimit(500L); mybatisPlusInterceptor.addInnerInterceptor(paginationInnerInterceptor); //設(shè)置請(qǐng)求的頁(yè)面大于最大頁(yè)后操作,true調(diào)回到首頁(yè),false繼續(xù)請(qǐng)求默認(rèn)false // paginationInterceptor.setOverflow(false);//設(shè)置最大單頁(yè)限制數(shù)量,默認(rèn)500條,-1不受限制 //paginationInterceptor.setLimit(500); //開(kāi)啟 count 的 join 優(yōu)化,只針對(duì)部分 left join return mybatisPlusInterceptor; } }
完結(jié)
到此這篇關(guān)于Mybatis-plus原生pages分頁(yè)未生效的解決方案的文章就介紹到這了,更多相關(guān)Mybatis-plus原生pages分頁(yè)未生效內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- SpringBoot使用mybatis-plus分頁(yè)查詢(xún)無(wú)效的問(wèn)題解決
- Mybatis-Plus 多表聯(lián)查分頁(yè)的實(shí)現(xiàn)代碼
- MyBatis-Plus 分頁(yè)查詢(xún)以及自定義sql分頁(yè)的實(shí)現(xiàn)
- MyBatis-Plus分頁(yè)插件不生效的解決方法
- 解決mybatis plus 一對(duì)多分頁(yè)查詢(xún)問(wèn)題
- MyBatis-Plus實(shí)現(xiàn)分頁(yè)的方法使用詳解
- MyBatis-Plus實(shí)現(xiàn)2種分頁(yè)方法(QueryWrapper查詢(xún)分頁(yè)和SQL查詢(xún)分頁(yè))
- MyBatis-Plus分頁(yè)時(shí)排序的實(shí)現(xiàn)方法
- Mybatis-Plus如何使用分頁(yè)實(shí)例詳解
- mybatis-plus分頁(yè)無(wú)效問(wèn)題解決
相關(guān)文章
Java中對(duì)null進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換的方法
小編對(duì)null進(jìn)行強(qiáng)轉(zhuǎn)會(huì)不會(huì)拋錯(cuò),非常的好奇,下面小編通過(guò)實(shí)例代碼給大家介紹Java中對(duì)null進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換的方法,感興趣的朋友參考下吧2018-09-09Java中Elasticsearch 實(shí)現(xiàn)分頁(yè)方式(三種方式)
Elasticsearch是用Java語(yǔ)言開(kāi)發(fā)的,并作為Apache許可條款下的開(kāi)放源碼發(fā)布,是一種流行的企業(yè)級(jí)搜索引擎,這篇文章主要介紹了Elasticsearch實(shí)現(xiàn)分頁(yè)的3種方式,需要的朋友可以參考下2022-07-07Opencv創(chuàng)建車(chē)牌圖片識(shí)別系統(tǒng)方法詳解
本文主要介紹了一個(gè)基于spring?boot+maven+opencv實(shí)現(xiàn)的圖像識(shí)別及訓(xùn)練項(xiàng)目,可以實(shí)現(xiàn)車(chē)牌識(shí)別功能,感興趣的可以跟隨小編一起試一試2022-01-01win7 64位系統(tǒng)JDK安裝配置環(huán)境變量教程
這篇文章主要為大家詳細(xì)介紹了win7 64位系統(tǒng)JDK安裝配置環(huán)境變量教程,感興趣的小伙伴們可以參考一下2016-06-06SpringBoot Controller Post接口單元測(cè)試示例
今天小編就為大家分享一篇關(guān)于SpringBoot Controller Post接口單元測(cè)試示例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2018-12-12Java如何通過(guò)Maven管理項(xiàng)目依賴(lài)
這篇文章主要介紹了Java如何通過(guò)Maven管理項(xiàng)目依賴(lài),幫助大家更好的理解和使用maven,感興趣的朋友可以了解下2020-10-10JavaScript中的isTrusted屬性及其應(yīng)用場(chǎng)景詳解
在現(xiàn)代 Web 開(kāi)發(fā)中,JavaScript 是構(gòu)建交互式應(yīng)用的核心語(yǔ)言,隨著前端技術(shù)的不斷發(fā)展,開(kāi)發(fā)者需要處理越來(lái)越多的復(fù)雜場(chǎng)景,例如事件處理、數(shù)據(jù)傳遞和狀態(tài)管理等,本文將通過(guò)一個(gè)實(shí)際案例,深入探討 isTrusted 屬性的來(lái)源、作用,需要的朋友可以參考下2025-01-01Java.lang.NullPointerException的錯(cuò)誤解決
Java中NullPointerException是一種常見(jiàn)的運(yùn)行時(shí)異常,通常發(fā)生在嘗試調(diào)用null對(duì)象的方法或訪(fǎng)問(wèn)其屬性時(shí),具有一定的參考價(jià)值,感興趣的可以了解一下2024-09-09