查询到List后再进行分页(mybatis-plus

如果您需要首先获取符合条件的所有数据,然后在内存中进行筛选,以满足特定条件,而不是在数据库层面进行条件查询,您可以继续使用您的原始实现。但是,为了正确实现分页,您需要对分页结果进行调整。以下是一个可能的改进版本:

java 复制代码
List<SysBeforeUser> sysBeforeUsers = baseMapper.selectList(sysBeforeUserQueryWrapper);
Page<SysBeforeUser> result = new Page<>(pageParam.getCurrent(), pageParam.getSize());

List<SysBeforeUser> pageEnd = new ArrayList<>();

if (!StringUtil.isEmpty(pageParam.getIsVip())) {
    for (SysBeforeUser sysBeforeUser : sysBeforeUsers) {
        if (sysBeforeUser.getIsVip().equals(pageParam.getIsVip())) {
            pageEnd.add(sysBeforeUser);
        }
    }
    result.setRecords(pageEnd.subList(
        (int) result.offset(), 
        Math.min((int) result.offset() + result.getSize(), pageEnd.size())
    ));
    result.setTotal(pageEnd.size());
} else {
    result.setRecords(sysBeforeUsers.subList(
        (int) result.offset(), 
        Math.min((int) result.offset() + result.getSize(), sysBeforeUsers.size())
    ));
    result.setTotal(sysBeforeUsers.size());
}

return result;

在这里,使用了 subList 方法来截取符合分页条件的记录范围,并将其设置为 resultrecords 属性。请注意,由于 subList 的索引参数是基于列表的索引,因此需要将 result.offset() 强制转换为 int 类型。

虽然这种方法可以满足您的需求,但请注意,它在性能上可能不如在数据库层面进行分页查询,特别是在数据量较大的情况下。如果性能是关键考虑因素,建议尽量在数据库层面进行分页查询。

result.setRecords(pageEnd.subList(

(int) result.offset(),

Math.min((int) result.offset() + result.getSize(), pageEnd.size())

));

result.setRecords(sysBeforeUsers.subList(

(int) result.offset(),

Math.min((int) result.offset() + result.getSize(), sysBeforeUsers.size())

));是什么 意思?

这两行代码使用了 Java 中 List 接口的 subList 方法,用于获取原始列表的一个子列表。具体来说,这两行代码的目的是截取符合分页条件的记录范围,并将其设置为 result 对象的 records 属性,即将这个子列表作为查询结果返回。

让我解释一下这两行代码的具体含义:

  1. pageEnd.subList((int) result.offset(), Math.min((int) result.offset() + result.getSize(), pageEnd.size()))

    • pageEnd 是您根据条件筛选得到的 SysBeforeUser 列表。
    • result.offset() 返回当前分页的偏移量,即从哪一条记录开始。
    • Math.min((int) result.offset() + result.getSize(), pageEnd.size()) 确保截取的范围不超过 pageEnd 的实际大小。
    • 因此,这一行代码截取了 pageEnd 列表中,从 result.offset()Math.min((int) result.offset() + result.getSize(), pageEnd.size()) 的子列表,并将其设置为 resultrecords 属性。
  2. sysBeforeUsers.subList((int) result.offset(), Math.min((int) result.offset() + result.getSize(), sysBeforeUsers.size()))

    • sysBeforeUsers 是从数据库中查询得到的所有 SysBeforeUser 列表。
    • result.offset() 返回当前分页的偏移量,即从哪一条记录开始。
    • Math.min((int) result.offset() + result.getSize(), sysBeforeUsers.size()) 确保截取的范围不超过 sysBeforeUsers 的实际大小。
    • 因此,这一行代码截取了 sysBeforeUsers 列表中,从 result.offset()Math.min((int) result.offset() + result.getSize(), sysBeforeUsers.size()) 的子列表,并将其设置为 resultrecords 属性。

这两行代码的目的是为了根据分页信息,从完整的记录集中截取出当前页的记录,以便于设置到 result 对象中返回给调用者。

不过建议还是使用IService的page(page, wrapper)方法,this.page(E page, Wrapper queryWrapper):

java 复制代码
default <E extends IPage<T>> E page(E page, Wrapper<T> queryWrapper) {
        return this.getBaseMapper().selectPage(page, queryWrapper);
    }
相关推荐
lingRJ777几秒前
微服务架构下的抉择:Consul vs. Eureka,服务发现该如何选型?
java·eureka·springcloud·consul·backend·microservices·servicediscovery
RainbowSea几秒前
问题:后端由于字符内容过长,前端展示精度丢失修复
java·spring boot·后端
C182981825754 分钟前
OOM电商系统订单缓存泄漏,这是泄漏还是溢出
java·spring·缓存
风象南18 分钟前
SpringBoot 控制器的动态注册与卸载
java·spring boot·后端
我是一只代码狗44 分钟前
springboot中使用线程池
java·spring boot·后端
hello早上好1 小时前
JDK 代理原理
java·spring boot·spring
PanZonghui1 小时前
Centos项目部署之运行SpringBoot打包后的jar文件
linux·spring boot
PanZonghui1 小时前
Centos项目部署之Java安装与配置
java·linux
沉着的码农2 小时前
【设计模式】基于责任链模式的参数校验
java·spring boot·分布式
zyxzyx6662 小时前
Flyway 介绍以及与 Spring Boot 集成指南
spring boot·笔记