SpringBoot+Mybatis-plus實現(xiàn)分頁查詢的示例代碼
分頁查詢就是實現(xiàn)前端能進(jìn)行翻頁功能實現(xiàn)、查詢功能實現(xiàn)等比如

這張圖片里面搜索功能和底下翻頁的功能、每頁展示多少條數(shù)據(jù)的功能
都是由我們后端返回的參數(shù) total、pages、records等前端接收實現(xiàn)的
意思是這些功能我們后端不僅要實現(xiàn)分頁功能,前端接收我們返回的參數(shù)也要實現(xiàn)相對應(yīng)的功能
后端只用返回查詢結(jié)果和返回的total等字段
那么我們?nèi)绾螌崿F(xiàn)呢
首先,根據(jù)這張圖,我們需要幾個類
實體類 ,DTO,以及VO
這幾個類來干嘛? DTO就是用來當(dāng)形參的,VO就是來當(dāng)返回信息的,實體類干嘛?先別急,聽我說
根據(jù)這張圖片,我們首先要實現(xiàn)對于人員姓名的模糊查詢,手機(jī)號的查詢,以及狀態(tài)的查詢
所以我們是不是就要傳三個字段username、phone、status呢
是的,然后我們定義一個dto類
@Data
@AllArgsConstructor
@NoArgsConstructor
@Api(tags = "用戶查詢列表")
public class QueryUserDto extends PageDto {
@ApiModelProperty(value = "賬號")
private String account;
@ApiModelProperty(value = "用戶姓名")
private String accName;
@ApiModelProperty(value = "手機(jī)號")
private String accPhone;
@ApiModelProperty(value = "是否啟用(1:啟用,0:停用)")
private Integer isEnable;
}Api這些注解是用的swagger的,相當(dāng)于是提示功能,這些都先不管,我們是不是定義好了幾個需要傳入的字段?ok ,那么我們剛剛說了既然是分頁功能,是不是要由total、pageSize等字段呢
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.Setter;
@Data
@Setter
@ApiModel(value = "分頁對象" ,description = "分頁查詢實體")
@NoArgsConstructor
public class PageDto {
@ApiModelProperty(value = "頁碼",required = true)
private Integer PageNumber=1;
@ApiModelProperty(value = "每頁顯示數(shù)量",required = true)
private Integer PageSize=10;
@ApiModelProperty("排序字段")
private String sortBy;
@ApiModelProperty("排序方式")
private Boolean isAsc;
}
這個就是我們需要傳入的分頁對象,可以說是一個查詢的模板,大家可以保存下來,要分頁的時候拿出來用就行了。我們剛剛定義的QueryUserDto繼承這個pageDto,相當(dāng)于pageDto是一個父類,但我們用的是QueryUserDto,在實際情況中,我們可以通過需要傳入哪些字段進(jìn)行查詢來定義我們QueryUserDto里面的字段
然后是返回對象VO,我們剛剛提到前端需要我們返回給他們Total,pages,records等字段,VO里面就封裝了這些字段,
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import java.util.List;
@Data
public class PageVO<T> {
@ApiModelProperty(value = "每頁顯示的條數(shù)")
private Long size =10L;
@ApiModelProperty(value = "當(dāng)前頁")
private Long current=1L;
@ApiModelProperty(value = "總條數(shù)")
private Long total;
@ApiModelProperty(value = "總頁數(shù)")
private Long pages;
@ApiModelProperty(value = "分頁數(shù)據(jù)")
private List<T> records;
}這里面就封裝了前端需要的字段,每次返回給前端都會默認(rèn)有這些字段,這也是一個模板,大家可以保存起來
然后就是具體的實現(xiàn)方法,首先就是mybatis-plus的分頁插件
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class MyBatisConfig {
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return interceptor;
}
}這個就是mybatis-plus提供的分頁插件功能,我們配置好后進(jìn)入下一步
創(chuàng)建相關(guān)的service接口類

里面的方法暫且可以不管,看PageUser這個方法
然后實現(xiàn)類serviceImpl
@Override
public R<?> PageUser(QueryUserDto queryUserDto) {
Page<AccountInfo> userPage = new Page<>(queryUserDto.getPageNumber(), queryUserDto.getPageSize());
LambdaQueryWrapper<AccountInfo> queryWrapper =new LambdaQueryWrapper<>();
if(queryUserDto.getIsEnable()!=null){
queryWrapper.eq(AccountInfo::getIsEnable,queryUserDto.getIsEnable());
}
String accName=queryUserDto.getAccName();
if (StringUtils.isNotBlank(accName)){
accName=accName.trim();
queryWrapper.like(AccountInfo::getAccName,accName);
}
String accPhone=queryUserDto.getAccPhone();
if (StringUtils.isNotBlank(accPhone)){
accPhone=accPhone.trim();
queryWrapper.like(AccountInfo::getAccPhone,accPhone);
}
String account=queryUserDto.getAccount();
if (StringUtils.isNotBlank(account)){
account=account.trim();
queryWrapper.like(AccountInfo::getAccount,account);
}
Page<AccountInfo> page = page(userPage,queryWrapper);
PageVO<AccountInfo> userPageVO = new PageVO<>();
BeanUtils.copyProperties(page,userPageVO);
return R.Success("查詢成功",userPageVO);
}關(guān)于形參我在上面講到過,我們不用pageDto實現(xiàn),而是用他的子類QueryUserDto來實現(xiàn),因為是繼承關(guān)系,所以我們傳入他的子類QueryUserDto。
我們看起來這個代碼很復(fù)雜,其實我們可以分成三個板塊看就很清晰結(jié)構(gòu)了
第一個

- 這部分聲明了一個
Page類型的變量userPage,Page是MyBatis-Plus中用于分頁查詢的類。 <AccountInfo>是泛型參數(shù),表示這個分頁查詢將會返回AccountInfo類型的對象列表。AccountInfo是一個自定義的Java類,通常代表了某種數(shù)據(jù)庫表的結(jié)構(gòu)。
- 這部分聲明了一個
new Page<>(queryUserDto.getPageNumber(), queryUserDto.getPageSize());:- 這部分通過
new Page<>()構(gòu)造函數(shù)創(chuàng)建了一個Page實例。 queryUserDto是一個數(shù)據(jù)傳輸對象(DTO),通常用于封裝從前端傳遞到后端的請求參數(shù)。在這個上下文中,它封裝了分頁查詢所需的頁碼和每頁大小。queryUserDto.getPageNumber()獲取請求中的頁碼(通常是從1開始的整數(shù))。頁碼指定了用戶想要查看哪一頁的數(shù)據(jù)。queryUserDto.getPageSize()獲取請求中的每頁大小,即每頁應(yīng)該顯示多少條數(shù)據(jù)。
- 這部分通過
第二個

這部分代碼是通過mybatis-plus中的Lambada來構(gòu)造查詢條件,作用就是人員姓名模糊查詢、狀態(tài)查詢、手機(jī)號查詢,trim()是來設(shè)置去除傳入?yún)?shù)的空格的,以便前端輸入帶有空格的數(shù)據(jù)時查詢不出來
第三個

調(diào)用page方法,傳入分頁信息(userPage)和查詢條件(queryWrapper),然后返回一個包含查詢結(jié)果和分頁信息的Page<AccountInfo>對象。
然后創(chuàng)建VO對象的實例,通過BeanUtils工具類將查詢出來的對象復(fù)制給VO對象,這就是VO的作用,用于返回信息
運行效果

總結(jié)
首先我們需要引入分頁插件配置,然后創(chuàng)建DTO和VO,DTO包含我們需要的進(jìn)行查詢的字段,繼承PageDto,VO是返回信息的對象,這樣做不會影響我們創(chuàng)建的實體類。
接下來就是service接口和serviceImpl實現(xiàn)類的創(chuàng)建,在實現(xiàn)類里面編寫我們分頁的邏輯
然后三部分結(jié)構(gòu),引入Page實例、查詢語句編寫、page方法進(jìn)行查詢并復(fù)制給VO對象用于返回信息
到此這篇關(guān)于SpringBoot+Mybatis-plus實現(xiàn)分頁查詢的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot Mybatis-plus 分頁查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot整合Mybatis與thymleft實現(xiàn)增刪改查功能詳解
MybatisPlus是國產(chǎn)的第三方插件,?它封裝了許多常用的CURDapi,免去了我們寫mapper.xml的重復(fù)勞動。本文將整合MybatisPlus實現(xiàn)增刪改查功能,感興趣的可以了解一下2022-12-12
springboot+vue實現(xiàn)阿里云oss大文件分片上傳的示例代碼
阿里云推出了直傳,本文主要介紹了springboot+vue實現(xiàn)阿里云oss大文件分片上傳的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06
java datetime數(shù)據(jù)類型去掉時分秒的案例詳解
在Java中,如果我們想要表示一個日期而不包括時間(時分秒),我們通常會使用java.time包中的LocalDate類,這篇文章主要介紹了java datetime數(shù)據(jù)類型去掉時分秒,需要的朋友可以參考下2024-06-06
Springboot配置suffix指定mvc視圖的后綴方法
這篇文章主要介紹了Springboot配置suffix指定mvc視圖的后綴方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07

