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}
    
相关推荐
_WndProc2 分钟前
C++ 日志输出
开发语言·c++·算法
Q_192849990610 分钟前
基于Spring Boot的摄影器材租赁回收系统
java·spring boot·后端
qq_4335545411 分钟前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
Code_流苏12 分钟前
VSCode搭建Java开发环境 2024保姆级安装教程(Java环境搭建+VSCode安装+运行测试+背景图设置)
java·ide·vscode·搭建·java开发环境
数据小爬虫@30 分钟前
如何高效利用Python爬虫按关键字搜索苏宁商品
开发语言·爬虫·python
ZJ_.32 分钟前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
Narutolxy37 分钟前
深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道20241223
开发语言·golang·gin
Hello.Reader44 分钟前
全面解析 Golang Gin 框架
开发语言·golang·gin
禁默1 小时前
深入浅出:AWT的基本组件及其应用
java·开发语言·界面编程
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架