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}
相关推荐
JavaEdge.2 分钟前
Chrome加载已解压的扩展程序-清单文件缺失或不可读取 无法加载清单
java
iReachers4 分钟前
HTML打包EXE配置管理教程:多项目打包设置一键保存、加载与切换
java·前端·javascript
武藤一雄7 分钟前
WPF中ViewModel之间的5种通讯方式
开发语言·前端·microsoft·c#·wpf
XiYang-DING9 分钟前
【Java】堆
java·开发语言
Lyyaoo.13 分钟前
【Java基础面经】Java 反射机制
java·开发语言·python
YXWik618 分钟前
Langchain4j(1)基础对话+连续对话+工具调用 + 流式响应+结构化 JSON 输出
java
m0_6948455728 分钟前
UVdesk部署教程:企业级帮助台系统实践
服务器·开发语言·后端·golang·github
泉飒28 分钟前
C2001: 常量中有换行符-QT解决办法-逆向思路
开发语言·qt
967729 分钟前
什么是 Thymeleaf?
java
Dream_sky分享35 分钟前
找类中字段属性不同工具类
java