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}
相关推荐
徐小黑ACG44 分钟前
GO语言 使用protobuf
开发语言·后端·golang·protobuf
0白露2 小时前
Apifox Helper 与 Swagger3 区别
开发语言
Tanecious.3 小时前
机器视觉--python基础语法
开发语言·python
叠叠乐3 小时前
rust Send Sync 以及对象安全和对象不安全
开发语言·安全·rust
战族狼魂3 小时前
CSGO 皮肤交易平台后端 (Spring Boot) 代码结构与示例
java·spring boot·后端
Tttian6224 小时前
Python办公自动化(3)对Excel的操作
开发语言·python·excel
xyliiiiiL4 小时前
ZGC初步了解
java·jvm·算法
杉之5 小时前
常见前端GET请求以及对应的Spring后端接收接口写法
java·前端·后端·spring·vue
hycccccch5 小时前
Canal+RabbitMQ实现MySQL数据增量同步
java·数据库·后端·rabbitmq
独好紫罗兰5 小时前
洛谷题单2-P5713 【深基3.例5】洛谷团队系统-python-流程图重构
开发语言·python·算法