news 2026/1/11 5:59:46

SpringBoot+Mybatis-plus实现分页查询(一看就会)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot+Mybatis-plus实现分页查询(一看就会)

分页查询就是实现前端能进行翻页功能实现、查询功能实现等比如

这张图片里面搜索功能和底下翻页的功能、每页展示多少条数据的功能

都是由我们后端返回的参数 total、pages、records等前端接收实现的

意思是这些功能我们后端不仅要实现分页功能,前端接收我们返回的参数也要实现相对应的功能

后端只用返回查询结果和返回的total等字段

那么我们如何实现呢

首先,根据这张图,我们需要几个类

实体类 ,DTO,以及VO

这几个类来干嘛? DTO就是用来当形参的,VO就是来当返回信息的,实体类干嘛?先别急,听我说

根据这张图片,我们首先要实现对于人员姓名的模糊查询,手机号的查询,以及状态的查询

所以我们是不是就要传三个字段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 = "手机号") private String accPhone; @ApiModelProperty(value = "是否启用(1:启用,0:停用)") private Integer isEnable; }

Api这些注解是用的swagger的,相当于是提示功能,这些都先不管,我们是不是定义好了几个需要传入的字段?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 = "每页显示数量",required = true) private Integer PageSize=10; @ApiModelProperty("排序字段") private String sortBy; @ApiModelProperty("排序方式") private Boolean isAsc; }

这个就是我们需要传入的分页对象,可以说是一个查询的模板,大家可以保存下来,要分页的时候拿出来用就行了。我们刚刚定义的QueryUserDto继承这个pageDto,相当于pageDto是一个父类,但我们用的是QueryUserDto,在实际情况中,我们可以通过需要传入哪些字段进行查询来定义我们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 = "每页显示的条数") private Long size =10L; @ApiModelProperty(value = "当前页") private Long current=1L; @ApiModelProperty(value = "总条数") private Long total; @ApiModelProperty(value = "总页数") private Long pages; @ApiModelProperty(value = "分页数据") private List<T> records; }

这里面就封装了前端需要的字段,每次返回给前端都会默认有这些字段,这也是一个模板,大家可以保存起来

然后就是具体的实现方法,首先就是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提供的分页插件功能,我们配置好后进入下一步

创建相关的service接口类

里面的方法暂且可以不管,看PageUser这个方法

然后实现类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); }

关于形参我在上面讲到过,我们不用pageDto实现,而是用他的子类QueryUserDto来实现,因为是继承关系,所以我们传入他的子类QueryUserDto。

我们看起来这个代码很复杂,其实我们可以分成三个板块看就很清晰结构了

第一个

    • 这部分声明了一个Page类型的变量userPagePage是MyBatis-Plus中用于分页查询的类。
    • <AccountInfo>是泛型参数,表示这个分页查询将会返回AccountInfo类型的对象列表。AccountInfo是一个自定义的Java类,通常代表了某种数据库表的结构。
  1. new Page<>(queryUserDto.getPageNumber(), queryUserDto.getPageSize());

    • 这部分通过new Page<>()构造函数创建了一个Page实例。
    • queryUserDto是一个数据传输对象(DTO),通常用于封装从前端传递到后端的请求参数。在这个上下文中,它封装了分页查询所需的页码和每页大小。
    • queryUserDto.getPageNumber()获取请求中的页码(通常是从1开始的整数)。页码指定了用户想要查看哪一页的数据。
    • queryUserDto.getPageSize()获取请求中的每页大小,即每页应该显示多少条数据。

第二个

这部分代码是通过mybatis-plus中的Lambada来构造查询条件,作用就是人员姓名模糊查询、状态查询、手机号查询,trim()是来设置去除传入参数的空格的,以便前端输入带有空格的数据时查询不出来

第三个

调用page方法,传入分页信息(userPage)和查询条件(queryWrapper),然后返回一个包含查询结果和分页信息的Page<AccountInfo>对象。

然后创建VO对象的实例,通过BeanUtils工具类将查询出来的对象复制给VO对象,这就是VO的作用,用于返回信息

运行效果

总结

首先我们需要引入分页插件配置,然后创建DTO和VO,DTO包含我们需要的进行查询的字段,继承PageDto,VO是返回信息的对象,这样做不会影响我们创建的实体类。

接下来就是service接口和serviceImpl实现类的创建,在实现类里面编写我们分页的逻辑

然后三部分结构,引入Page实例、查询语句编写、page方法进行查询并复制给VO对象用于返回信息

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/11 5:57:13

PDF-Extract-Kit机器学习模型:YOLO检测原理与应用

PDF-Extract-Kit机器学习模型&#xff1a;YOLO检测原理与应用 1. 引言&#xff1a;PDF智能提取的技术演进与挑战 随着数字化文档的广泛应用&#xff0c;从PDF中高效、准确地提取结构化信息已成为科研、教育和企业办公中的核心需求。传统基于规则或模板的解析方法在面对复杂版…

作者头像 李华
网站建设 2026/1/11 5:54:01

科哥PDF-Extract-Kit技巧分享:批量处理PDF的自动化脚本

科哥PDF-Extract-Kit技巧分享&#xff1a;批量处理PDF的自动化脚本 1. 引言 1.1 业务场景描述 在科研、教育和文档数字化工作中&#xff0c;PDF文件中常包含大量结构化内容&#xff0c;如数学公式、表格、图文混排等。手动提取这些信息效率低下且容易出错。科哥开发的 PDF-E…

作者头像 李华
网站建设 2026/1/11 5:52:09

面试挂了!1 万 QPS+500ms 接口,我竟说不出线程池该设多少?

上周帮学弟模拟复盘后端面试&#xff0c;一道 “高并发线程池设计题” 直接把他问懵了&#xff1a; 我&#xff1a;“核心接口响应时间 500ms&#xff0c;要扛 1 万 QPS&#xff0c;线程池核心数、最大数怎么设&#xff1f;需要多少台机器&#xff1f;” 学弟想都没想&#x…

作者头像 李华
网站建设 2026/1/11 5:47:09

PDF-Extract-Kit保姆级指南:自定义输出格式开发

PDF-Extract-Kit保姆级指南&#xff1a;自定义输出格式开发 1. 引言与背景 1.1 PDF智能提取的工程挑战 在科研、教育和出版领域&#xff0c;PDF文档承载了大量结构化信息&#xff0c;如公式、表格、段落和图像。然而&#xff0c;传统PDF解析工具往往只能进行线性文本提取&am…

作者头像 李华
网站建设 2026/1/11 5:45:44

PDF-Extract-Kit版本升级指南:从v1.0到最新版迁移

PDF-Extract-Kit版本升级指南&#xff1a;从v1.0到最新版迁移 1. 引言&#xff1a;为何需要版本迁移&#xff1f; PDF-Extract-Kit 是由开发者“科哥”打造的一款开源PDF智能提取工具箱&#xff0c;专为科研、教育、出版等场景设计&#xff0c;支持布局检测、公式识别、OCR文…

作者头像 李华
网站建设 2026/1/11 5:44:46

PDF-Extract-Kit保姆级指南:错误处理与重试机制

PDF-Extract-Kit保姆级指南&#xff1a;错误处理与重试机制 1. 引言&#xff1a;构建健壮PDF智能提取系统的必要性 在实际工程实践中&#xff0c;PDF文档的来源复杂、格式多样&#xff0c;从扫描件到电子版&#xff0c;从清晰排版到模糊图像&#xff0c;各类边缘情况层出不穷…

作者头像 李华