欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringBoot+Mybatis-plus實(shí)現(xiàn)分頁(yè)查詢的示例代碼

 更新時(shí)間:2025年02月05日 10:29:04   作者:2301_81439082  
本文主要介紹了SpringBoot+Mybatis-plus實(shí)現(xiàn)分頁(yè)查詢的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

分頁(yè)查詢就是實(shí)現(xiàn)前端能進(jìn)行翻頁(yè)功能實(shí)現(xiàn)、查詢功能實(shí)現(xiàn)等比如

這張圖片里面搜索功能和底下翻頁(yè)的功能、每頁(yè)展示多少條數(shù)據(jù)的功能

都是由我們后端返回的參數(shù) total、pages、records等前端接收實(shí)現(xiàn)的

意思是這些功能我們后端不僅要實(shí)現(xiàn)分頁(yè)功能,前端接收我們返回的參數(shù)也要實(shí)現(xiàn)相對(duì)應(yīng)的功能

后端只用返回查詢結(jié)果和返回的total等字段

那么我們?nèi)绾螌?shí)現(xiàn)呢

首先,根據(jù)這張圖,我們需要幾個(gè)類 

實(shí)體類 ,DTO,以及VO

這幾個(gè)類來干嘛? DTO就是用來當(dāng)形參的,VO就是來當(dāng)返回信息的,實(shí)體類干嘛?先別急,聽我說

根據(jù)這張圖片,我們首先要實(shí)現(xiàn)對(duì)于人員姓名的模糊查詢,手機(jī)號(hào)的查詢,以及狀態(tài)的查詢

所以我們是不是就要傳三個(gè)字段username、phone、status呢

是的,然后我們定義一個(gè)dto類

@Data
@AllArgsConstructor
@NoArgsConstructor
@Api(tags = "用戶查詢列表")
public class QueryUserDto extends PageDto {

    @ApiModelProperty(value = "賬號(hào)")
    private String account;
    @ApiModelProperty(value = "用戶姓名")
    private String accName;
   @ApiModelProperty(value = "手機(jī)號(hào)")
    private String accPhone;
    @ApiModelProperty(value = "是否啟用(1:啟用,0:停用)")
    private Integer isEnable;
}

Api這些注解是用的swagger的,相當(dāng)于是提示功能,這些都先不管,我們是不是定義好了幾個(gè)需要傳入的字段?ok ,那么我們剛剛說了既然是分頁(yè)功能,是不是要由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 = "分頁(yè)對(duì)象" ,description = "分頁(yè)查詢實(shí)體")
@NoArgsConstructor
public class PageDto {
    @ApiModelProperty(value = "頁(yè)碼",required = true)
    private  Integer PageNumber=1;
    @ApiModelProperty(value = "每頁(yè)顯示數(shù)量",required = true)
    private  Integer PageSize=10;
    @ApiModelProperty("排序字段")
    private  String sortBy;
    @ApiModelProperty("排序方式")
    private  Boolean isAsc;

}

這個(gè)就是我們需要傳入的分頁(yè)對(duì)象,可以說是一個(gè)查詢的模板,大家可以保存下來,要分頁(yè)的時(shí)候拿出來用就行了。我們剛剛定義的QueryUserDto繼承這個(gè)pageDto,相當(dāng)于pageDto是一個(gè)父類,但我們用的是QueryUserDto,在實(shí)際情況中,我們可以通過需要傳入哪些字段進(jìn)行查詢來定義我們QueryUserDto里面的字段

然后是返回對(duì)象VO,我們剛剛提到前端需要我們返回給他們Total,pages,records等字段,VO里面就封裝了這些字段,

import io.swagger.annotations.ApiModelProperty;
import lombok.Data;

import java.util.List;
@Data
public class PageVO<T> {
   @ApiModelProperty(value = "每頁(yè)顯示的條數(shù)")
    private  Long size =10L;
   @ApiModelProperty(value = "當(dāng)前頁(yè)")
    private Long current=1L;
   @ApiModelProperty(value = "總條數(shù)")
    private Long total;
   @ApiModelProperty(value = "總頁(yè)數(shù)")
    private Long pages;
   @ApiModelProperty(value = "分頁(yè)數(shù)據(jù)")
    private List<T> records;
}

這里面就封裝了前端需要的字段,每次返回給前端都會(huì)默認(rèn)有這些字段,這也是一個(gè)模板,大家可以保存起來

然后就是具體的實(shí)現(xiàn)方法,首先就是mybatis-plus的分頁(yè)插件

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;
    }
}

這個(gè)就是mybatis-plus提供的分頁(yè)插件功能,我們配置好后進(jìn)入下一步

創(chuàng)建相關(guān)的service接口類

里面的方法暫且可以不管,看PageUser這個(gè)方法

然后實(shí)現(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實(shí)現(xiàn),而是用他的子類QueryUserDto來實(shí)現(xiàn),因?yàn)槭抢^承關(guān)系,所以我們傳入他的子類QueryUserDto。

我們看起來這個(gè)代碼很復(fù)雜,其實(shí)我們可以分成三個(gè)板塊看就很清晰結(jié)構(gòu)了

第一個(gè)

    • 這部分聲明了一個(gè)Page類型的變量userPagePage是MyBatis-Plus中用于分頁(yè)查詢的類。
    • <AccountInfo>是泛型參數(shù),表示這個(gè)分頁(yè)查詢將會(huì)返回AccountInfo類型的對(duì)象列表。AccountInfo是一個(gè)自定義的Java類,通常代表了某種數(shù)據(jù)庫(kù)表的結(jié)構(gòu)。
  • new Page<>(queryUserDto.getPageNumber(), queryUserDto.getPageSize());

    • 這部分通過new Page<>()構(gòu)造函數(shù)創(chuàng)建了一個(gè)Page實(shí)例。
    • queryUserDto是一個(gè)數(shù)據(jù)傳輸對(duì)象(DTO),通常用于封裝從前端傳遞到后端的請(qǐng)求參數(shù)。在這個(gè)上下文中,它封裝了分頁(yè)查詢所需的頁(yè)碼和每頁(yè)大小。
    • queryUserDto.getPageNumber()獲取請(qǐng)求中的頁(yè)碼(通常是從1開始的整數(shù))。頁(yè)碼指定了用戶想要查看哪一頁(yè)的數(shù)據(jù)。
    • queryUserDto.getPageSize()獲取請(qǐng)求中的每頁(yè)大小,即每頁(yè)應(yīng)該顯示多少條數(shù)據(jù)。  

第二個(gè)

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

第三個(gè)

調(diào)用page方法,傳入分頁(yè)信息(userPage)和查詢條件(queryWrapper),然后返回一個(gè)包含查詢結(jié)果和分頁(yè)信息的Page<AccountInfo>對(duì)象。

然后創(chuàng)建VO對(duì)象的實(shí)例,通過BeanUtils工具類將查詢出來的對(duì)象復(fù)制給VO對(duì)象,這就是VO的作用,用于返回信息

運(yùn)行效果

總結(jié)

首先我們需要引入分頁(yè)插件配置,然后創(chuàng)建DTO和VO,DTO包含我們需要的進(jìn)行查詢的字段,繼承PageDto,VO是返回信息的對(duì)象,這樣做不會(huì)影響我們創(chuàng)建的實(shí)體類。

接下來就是service接口和serviceImpl實(shí)現(xiàn)類的創(chuàng)建,在實(shí)現(xiàn)類里面編寫我們分頁(yè)的邏輯

然后三部分結(jié)構(gòu),引入Page實(shí)例、查詢語句編寫、page方法進(jìn)行查詢并復(fù)制給VO對(duì)象用于返回信息 

到此這篇關(guān)于SpringBoot+Mybatis-plus實(shí)現(xiàn)分頁(yè)查詢的示例代碼的文章就介紹到這了,更多相關(guān)SpringBoot Mybatis-plus 分頁(yè)查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • hibernate中HQL如何調(diào)用自定義函數(shù)

    hibernate中HQL如何調(diào)用自定義函數(shù)

    這篇文章主要介紹了hibernate中HQL如何調(diào)用自定義函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java并發(fā)編程中的CompletableFuture使用詳解

    Java并發(fā)編程中的CompletableFuture使用詳解

    這篇文章主要介紹了Java并發(fā)編程中的CompletableFuture使用詳解,Future接口定義了操作異步任務(wù)執(zhí)行的一些方法,如獲取異步任務(wù)執(zhí)行的結(jié)果、取消任務(wù)的執(zhí)行、判斷任務(wù)是否被取消,判斷任務(wù)是否執(zhí)行完畢等,需要的朋友可以參考下
    2023-12-12
  • jdbc鏈接遠(yuǎn)程數(shù)據(jù)庫(kù)進(jìn)行修改url操作

    jdbc鏈接遠(yuǎn)程數(shù)據(jù)庫(kù)進(jìn)行修改url操作

    這篇文章主要為大家詳細(xì)介紹了jdbc鏈接遠(yuǎn)程數(shù)據(jù)庫(kù)進(jìn)行修改url操作,感興趣的小伙伴們可以參考一下
    2016-06-06
  • java輸入數(shù)字,輸出倒序的實(shí)例

    java輸入數(shù)字,輸出倒序的實(shí)例

    這篇文章主要介紹了java輸入數(shù)字,輸出倒序的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • JAVA中 終止線程的方法介紹

    JAVA中 終止線程的方法介紹

    JAVA中 終止線程的方法介紹,需要的朋友可以參考一下
    2013-03-03
  • Java函數(shù)式接口Supplier接口實(shí)例詳解

    Java函數(shù)式接口Supplier接口實(shí)例詳解

    這篇文章主要介紹了Java函數(shù)式接口Supplier接口實(shí)例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • Java軟件編程培訓(xùn)機(jī)構(gòu)靠譜嗎

    Java軟件編程培訓(xùn)機(jī)構(gòu)靠譜嗎

    隨著網(wǎng)絡(luò)信息化的快速發(fā)展,Java培訓(xùn)受到越來越多人的青睞,目前Java工程師的薪資水平在不斷攀升,但是有好多企業(yè)還是招不到合適的人才,為什么呢
    2017-04-04
  • java實(shí)現(xiàn)簡(jiǎn)單超市管理系統(tǒng)

    java實(shí)現(xiàn)簡(jiǎn)單超市管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)單超市管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • SpringBoot框架整合SwaggerUI的示例代碼

    SpringBoot框架整合SwaggerUI的示例代碼

    項(xiàng)目中使用了很多現(xiàn)成的框架,都是項(xiàng)目經(jīng)理、架構(gòu)師帶來的,從來沒有自己整合過,今天給大家介紹下SpringBoot框架整合SwaggerUI的過程,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • JAVACORE與HEAPDUMP生成方法

    JAVACORE與HEAPDUMP生成方法

    JavaCore文件主要保存的是Java應(yīng)用各線程在某一時(shí)刻的運(yùn)行的位置,即JVM執(zhí)行到哪一個(gè)類、哪一個(gè)方法、哪一個(gè)行上,它是一個(gè)文本文件,打開后可以看到每一個(gè)線程的執(zhí)行棧,以stack?trace的顯示,本文介紹JAVACORE與HEAPDUMP生成大法,感興趣的朋友跟隨小編一起看看吧
    2024-08-08

最新評(píng)論