MyBatis-Plus:通用分页实体封装

分页查询实体:PageQuery

package com.example.demo.demos.model.query;


import com.baomidou.mybatisplus.core.metadata.OrderItem;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.Data;
import org.springframework.util.StringUtils;

/**
 * 分页查询实体
 */
@Data
public class PageQuery {

    //页码
    private Integer pageNo = 1;

    //分页大小
    private Integer pageSize = 10;

    //排序字段
    private String sortBy;

    //是否升序
    private Boolean isIncrease = true;

    /**
     * PageQuery转Page
     *
     * @param orderItem 排序条件
     * @return Page对象
     */
    public <T> Page<T> toMyBatisPlusPage(OrderItem... orderItem) {
        //TODO:构建分页条件
        //分页条件
        Page<T> page = new Page<>(pageNo, pageSize);
        //排序条件
        if (StringUtils.hasText(sortBy)) {
            page.addOrder(new OrderItem(sortBy, isIncrease));
        } else if (orderItem != null) {
            //默认按照更新时间排序-[此处改为默认按照id排序]
            page.addOrder(orderItem);
        }
        //返回
        return page;
    }

    /**
     * PageQuery转Page:根据Id排序
     *
     * @param orderBy    排序字段
     * @param isIncrease 是否升序
     * @return Page对象
     */
    public <T> Page<T> toMyBatisPlusPage(String orderBy, Boolean isIncrease) {
        return toMyBatisPlusPage(new OrderItem(orderBy, isIncrease));
    }

    /**
     * PageQuery转Page:根据Id排序
     *
     * @return Page对象
     */
    public <T> Page<T> toMyBatisPlusPageSortById() {
        return toMyBatisPlusPage(new OrderItem("id", true));
    }

    /**
     * PageQuery转Page:根据create_time排序
     *
     * @return Page对象
     */
    public <T> Page<T> toMyBatisPlusPageSortByCreateTime() {
        return toMyBatisPlusPage(new OrderItem("create_time", true));
    }

    /**
     * PageQuery转Page:根据update_time排序
     *
     * @return Page对象
     */
    public <T> Page<T> toMyBatisPlusPageSortByUpdateTime() {
        return toMyBatisPlusPage(new OrderItem("update_time", true));
    }
}

分页响应实体:PageDTO

package com.example.demo.demos.model.dto;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import lombok.Data;
import org.springframework.beans.BeanUtils;
import org.springframework.util.CollectionUtils;

import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.function.Function;
import java.util.stream.Collectors;

/**
 * 分页查询结果
 */
@Data
public class PageDTO<T> {

    //总条数
    private Long total;

    //总页数
    private Long pages;

    //集合
    private List<T> list;

    /**
     * Page转换为PageDTO
     *
     * @param page  MyBatis Plus分页对象
     * @param clazz 类型参数
     * @return PageDTO
     */
    public static <PO, VO> PageDTO<VO> of(Page<PO> page, Class<VO> clazz) {
        //TODO:构建Vo结果
        PageDTO<VO> pageDTO = new PageDTO<>();
        //总条数
        pageDTO.setTotal(page.getTotal());
        //总页数
        pageDTO.setPages(page.getPages());
        //当前页数据
        List<PO> records = page.getRecords();
        //转换为vo
        if (CollectionUtils.isEmpty(records)) {
            pageDTO.setList(Collections.emptyList());
            return pageDTO;
        }
        //for
        List<VO> voList = new ArrayList<>(records.size());
        records.forEach(po -> {
            try {
                VO vo = clazz.newInstance();
                BeanUtils.copyProperties(po, vo, clazz);
                voList.add(vo);
            } catch (InstantiationException | IllegalAccessException e) {
                e.printStackTrace();
            }
        });
        pageDTO.setList(voList);
        //返回结果
        return pageDTO;
    }


    /**
     * Page转换为PageDTO-【自定义PO->VO的转换方法】
     *
     * @param page  MyBatis Plus分页对象
     * @param convertor PO->VO的转换逻辑
     * @return PageDTO
     */
    public static <PO, VO> PageDTO<VO> of(Page<PO> page, Function<PO,VO> convertor) {
        //TODO:构建Vo结果
        PageDTO<VO> pageDTO = new PageDTO<>();
        //总条数
        pageDTO.setTotal(page.getTotal());
        //总页数
        pageDTO.setPages(page.getPages());
        //当前页数据
        List<PO> records = page.getRecords();
        //转换为vo
        if (CollectionUtils.isEmpty(records)) {
            pageDTO.setList(Collections.emptyList());
            return pageDTO;
        }
        List<VO> voList = records.stream().map(convertor).collect(Collectors.toList());
        pageDTO.setList(voList);
        //返回结果
        return pageDTO;
    }


}

使用示例

封装之前

  @Override
    public PageDTO<ProductVo> queryProductsPage(ProductQuery productQuery) {
        //获取参数
        String name = productQuery.getName();
        Boolean status = productQuery.getStatus();
        Double minPrice = productQuery.getMinPrice();
        Double maxPrice = productQuery.getMaxPrice();
        //TODO:构建分页条件
        //分页条件
        Page<Product> page = new Page<>(productQuery.getPageNo(), productQuery.getPageSize());
        //排序条件
        if (StringUtils.hasText(productQuery.getSortBy())){
            page.addOrder(new OrderItem(productQuery.getSortBy(),productQuery.getIsIncrease()));
        }else{
            //默认按照更新时间排序-[此处改为默认按照id排序]
            page.addOrder(new OrderItem("id",true));
        }
        //TODO:分页查询
        Page<Product> pageResult = lambdaQuery()
                .like(name != null && name != "", Product::getName, name)
                .eq(status != null, Product::getStatus, status)
                .ge(minPrice != null && minPrice != 0, Product::getPrice, minPrice)
                .le(maxPrice != null && maxPrice != 0, Product::getPrice, maxPrice)
                .page(page);
        //TODO:构建Vo结果
        PageDTO<ProductVo> productPageDTO = new PageDTO<>();
        //总条数
        productPageDTO.setTotal(pageResult.getTotal());
        //总页数
        productPageDTO.setPages(pageResult.getPages());
        //当前页数据
        List<Product> records = pageResult.getRecords();
        //转换为vo
        if (CollectionUtils.isEmpty(records)){
            productPageDTO.setList(Collections.emptyList());
            return productPageDTO;
        }
        //返回结果
        List<ProductVo> productVoList = records.stream().map(product -> {
            ProductVo productVo = new ProductVo();
            BeanUtils.copyProperties(product, productVo);
            return productVo;
        }).collect(Collectors.toList());
        productPageDTO.setList(productVoList);
        return productPageDTO;
    }

封装之后

  @Override
    public PageDTO<ProductVo> queryProductsPage(ProductQuery productQuery) {
        //获取参数
        String name = productQuery.getName();
        Boolean status = productQuery.getStatus();
        Double minPrice = productQuery.getMinPrice();
        Double maxPrice = productQuery.getMaxPrice();
        //TODO:构建分页条件
        //调用封装好的方法
        Page<Product> page = productQuery.toMyBatisPlusPageSortById();
        //TODO:分页查询
        Page<Product> pageResult = lambdaQuery()
                .like(name != null && name != "", Product::getName, name)
                .eq(status != null, Product::getStatus, status)
                .ge(minPrice != null && minPrice != 0, Product::getPrice, minPrice)
                .le(maxPrice != null && maxPrice != 0, Product::getPrice, maxPrice)
                .page(page);
        //TODO:构建Vo结果
        //方式1:默认转换PO->VO
//        return PageDTO.of(pageResult, ProductVo.class);
        //方式2:自定义转换PO->VO
        return PageDTO.of(pageResult,(product -> {
            //自定义转换逻辑
            ProductVo productVo = new ProductVo();
            BeanUtils.copyProperties(product,productVo);
            return productVo;
        }));
    }

接口测试

        这里省略Controller、Mapper、Model、Service等其它代码。

        查询参数:

查询参数

        查询结果:

{
    "code": 200,
    "data": {
        "total": 3,
        "pages": 2,
        "list": [
            {
                "id": 2,
                "name": "冰可乐",
                "price": 12.12,
                "address": "淮阳",
                "status": false,
                "createTime": "2024-02-18 00:35:07",
                "updateTime": null,
                "enumState": 2,
                "info": "{\"bar\": \"baz\", \"balance\": 7.77, \"active\": false}"
            },
            {
                "id": 4,
                "name": "雪糕",
                "price": 38.47,
                "address": "阜阳",
                "status": true,
                "createTime": "2024-02-18 01:23:12",
                "updateTime": null,
                "enumState": 1,
                "info": "{\"bar\": \"baz\", \"balance\": 7.77, \"active\": false}"
            }
        ]
    },
    "message": "ok"
}

 

  • 8
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Mybatis-plusMyBatis增强工具包,用于简化CRUD操作。该工具包为MyBatis提供了一些高效,有用,即用的功能,使用它可以有效地节省您的开发时间。 Mybatis-plus特征: 与MyBatis完全兼容 启动时自动配置 开箱即用的用于操作数据库的界面 强大而灵活的条件包装器 生成主键的多种策略 Lambda样式的API 全能和高度可定制的代码生成器 自动分页操作 SQL注入防御 支持活动记录 支持可插拔的自定义界面 内置许多有用的扩展 Mybatis-plus功能: 1、单表CURD(简单 + 批量)操作,自动完成(支持 like 比较等查询)。 2、分页插件,Count查询自动或自定义SQL查询。 3、Spring根据不同环境加载不同配置支持(支持typeAliasesPackage通配符扫描)。 【自动生成Entity  Mapper  Service文件】 Mybatis-plus更新日志: v3.4.3 增加瀚高数据库支持 增加注解 Order By 支持默认排序 Wrapper exists notExists orderBy groupBy 支持参数绑定 Wrapper 支持 setParamAlias 其它优化 优化 KeyGenerator 支持多实现多数据源注入 增强 ServiceImpl 泛型推断,解决多继承与代理问题 新增 PageDto 用于微服务对象传输序列化 新增 Page 提供静态 of 构造方式 增加代理 MethodHandleProxies 对 lambda 调试支持 调整 ActiveRecord 日志对象初始化 调整 ActiveRecord 模式 Model 类开发 pkVal 方法外部可用 删除标记过时代码 优化枚举值获取方式 分页 count 安全处理 Sequence 方法支持重写支持 升级 Mybatis 3.5.7 修复自动配置 lazy-initialization 无属性提示 修复 mysql on duplicate key update 字段名判断为表名问题 修复 lambda 条件 npe 异常 重构 lambda 信息提取方法 获取 lambda 信息不在序列化 合并 gitee pulls/ 141 fixed github issues/3208 3016 fixed github issues/3482 数据权限处理器支持 union all 调整事务未启用打印提示信息 单元测试优化相关依赖升级

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是席木木啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值