Mybatis-Plus实现分页查询

一、Mybatis-Plus通过QueryWrapper

1.1 分页查询(针对需要聚合的数据)

  1. 创建一个 QueryWrapper 实例,用于构建查询条件,OpHighRiskExposureDO为与数据库对应的实体类。

    QueryWrapper<OpHighRiskExposureDO> wrapper = new QueryWrapper<>();

2.使用分页工厂创建分页对象,执行查询,并返回结果集,结果类型为 Page<Map<String, Object>>;其中 selectMapsPage 方法将查询结果以 Map<String, Object> 的形式返回。PageFactory.buildPage(opHighRiskExposureReq)是用于构建一个Page对象。

Page<Map<String, Object>> page = opHighRiskExposureMapper.selectMapsPage(PageFactory.buildPage(opHighRiskExposureReq), wrapper);
  1. 将查询结果转换为目标分页结果类型 Page<OpHighRiskExposureRespVO>,并设置分页信息 ; 设置记录列表、当前页、每页大小和总记录数,最后通过工厂方法返回封装的 PageResult。

    PageResultFactory.createPageResult(new Page<OpHighRiskExposureRespVO>()
    .setRecords(exposureRespList) // 设置查询结果转换后的记录列表
    .setCurrent(page.getCurrent()) // 设置当前页号
    .setSize(page.getSize()) // 设置每页记录数
    .setTotal(page.getTotal())); // 设置总记录数

1.2 分页查询(不需要聚合的情况,三行解决分页查询问题)

  • QueryWrapper:用于构建查询条件和排序规则。

  • 选择字段与排序 :选择所有字段并按 exposure_time 降序排列。

  • 分页查询 :使用 PageFactory.buildPage 方法创建分页对象,并执行查询,获取分页数据。

  • 结果转换 :使用 PageResultFactory.createPageResult 将查询结果转换为指定的分页结果类型并返回。

  • 注意:这里的OpHighRiskExposureDO是和你数据库里建的表的字段和类型一一对应的,不能改变,OpHighRiskExposureRespVO是你和前端交互的实体类,字段名字和OpHighRiskExposureDO大差不差,但是字段类型可以根据前端需求作出改变。

    // 定义查询高危暴露数据的方法,返回分页结果 PageResult<OpHighRiskExposureRespVO>
    public PageResult<OpHighRiskExposureRespVO> queryHighRiskExposures(OpHighRiskExposureReq opHighRiskExposureReq) {

      // 创建 QueryWrapper 实例,用于构建查询条件
      QueryWrapper<OpHighRiskExposureDO> wrapper = new QueryWrapper<>();
    
      // 选择所有字段,并按 exposure_time 字段进行降序排序
      // select("*") 表示选择所有列,orderByDesc 设置降序排列
      wrapper.select("*").orderByDesc("exposure_time");
    
      // 使用分页工厂类创建分页对象,并执行查询
      // selectPage 方法返回分页结果 Page<OpHighRiskExposureDO>,包含查询结果及分页信息
      Page<OpHighRiskExposureDO> page = opHighRiskExposureMapper.selectPage(PageFactory.buildPage(opHighRiskExposureReq), wrapper);
    
      // 使用工厂方法 createPageResult,将查询结果转换为 PageResult<OpHighRiskExposureRespVO> 类型并返回
      // 这里的 OpHighRiskExposureRespVO.class 指定了转换的目标类型
      return PageResultFactory.createPageResult(page, OpHighRiskExposureRespVO.class);
    

    }

二、Mybatis-Plus通过XML文件实现分页查

1.首先根据传进来的请求体建立一个page对象

Page<AttackedCustomersRespVO> page = PageFactory.buildPage(attackedCustomersReqDTO);

2.调用mapper时候需要把这个page对象传入

   Page<AttackedCustomersRespVO> pageResult = customerRiskMonitoringMapper.getAttackedCustomersPage(page, customerScope, sortType, evtTimeBegin, evtTimeEnd, orgPathList, orgName);

注意:mapper中的对象要返回Page对象,这样xml文件才会自动解析

Page<AttackedCustomersRespVO> getAttackedCustomersPage(Page<AttackedCustomersRespVO> page,
                                                           @Param("customerScope") Integer customerScope,
                                                           @Param("sortType") Integer sortType,
                                                           @Param("startTime") Date startTime,
                                                           @Param("endTime") Date endTime,
                                                           @Param("orgPathList") List<String> orgPathList,
                                                           @Param("orgName") String orgName);
  1. 构造返回分页对象

    return PageResultFactory.createPageResult(pageResult);

4.xml文件中都不用传page参数

在 MyBatis 中,如果你看了 XML 映射文件,发现根本没有显式地使用 Page 参数,依然能实现分页的原因是 MyBatis-Plus 提供了 分页插件(PaginationInterceptor)和自动分页功能,分页的实现实际上是通过拦截器在执行 SQL 查询之前自动处理的,而不需要在 XML 中手动编写分页逻辑。

如何实现自动分页?

  • 分页插件的拦截作用 : MyBatis-Plus 通过其分页插件(PaginationInterceptor)来拦截和修改查询 SQL。分页插件会在执行查询之前检查 Page 类型的参数,获取页码和每页的记录数,然后在查询的 SQL 中自动加入 LIMIT 或其他数据库特有的分页语句。你并不需要在 XML 中显式地处理分页。

  • Page 对象的作用 : 当你传入 Page 类型的参数时,MyBatis-Plus 会自动识别该对象,并在内部对 SQL 进行修改。Page 对象封装了当前页码、每页记录数等信息,这些信息会在执行 SQL 查询时被用到。

  • 没有显式调用 Page 参数的原因 : 在 XML 中并不需要显式地使用 Page 参数,因为分页插件已经完成了对 SQL 的自动修改。分页插件会动态生成分页相关的 SQL 语句,而 XML 文件中的 SQL 只需要关注查询的基本条件和字段,不需要考虑分页逻辑。

  • 分页插件初始化在 MyBatis-Plus 中,分页插件通常在配置类中初始化,使用 @BeanSqlSessionFactory 配置等方式,将分页插件 PaginationInterceptor 注入到 MyBatis 的执行器中。

  • 当你调用该方法时,Page<AttackedCustomersRespVO> 会携带分页信息(例如,当前页码和每页条数)。分页插件会自动读取这些信息,并在执行查询时修改 SQL,生成类似下面的分页查询:

    SELECT * FROM attacked_customers
    WHERE customer_scope = #{customerScope}
    AND sort_type = #{sortType}
    AND start_time >= #{startTime}
    AND end_time <= #{endTime}
    LIMIT #{page.start}, #{page.size}
    
相关推荐
以卿a1 小时前
C++ 模板初阶
开发语言·c++
s:1031 小时前
【框架】参考 Spring Security 安全框架设计出,轻量化高可扩展的身份认证与授权架构
java·开发语言
道不尽世间的沧桑2 小时前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
久绊A2 小时前
Python 基本语法的详细解释
开发语言·windows·python
南山十一少4 小时前
Spring Security+JWT+Redis实现项目级前后端分离认证授权
java·spring·bootstrap
软件黑马王子5 小时前
C#初级教程(4)——流程控制:从基础到实践
开发语言·c#
闲猫5 小时前
go orm GORM
开发语言·后端·golang
427724005 小时前
IDEA使用git不提示账号密码登录,而是输入token问题解决
java·git·intellij-idea
chengooooooo6 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
李长渊哦6 小时前
常用的 JVM 参数:配置与优化指南
java·jvm