jpa条件分页查询,逻辑过滤

该文章介绍了如何在JPA进行条件分页查询后,对Page对象的内容进行逻辑处理,包括对查询结果的list进行映射转换,去重,以及根据特定条件过滤和更新总条数。同时展示了使用BeanUtils进行对象属性复制的方法。
摘要由CSDN通过智能技术生成

背景:jpa条件分页查询完之后,进行逻辑处理,非数据库所有字段


一、Page对象使用

Page对象,其中totalElement为查询条数,pageable为查询条件,content为包含的list

可以利用此来构建新的Page对象,对content进行处理,以及查询的条数处理

二、代码演示

public Page<UserStaffVo> listVoWithLabor(UserStaffEntity staff) {
        Page<UserStaffEntity> source = staffService.selectPage(staff);
        List<UserStaffEntity> sourceList = source.getContent();
        Map<String, String> map=new HashMap<>(16);
        int targetTotal= (int) source.getTotalElements();
        //拿到这个用户现在所绑定有效的合同
        List<String> userList = sourceList.stream().map(UserStaffEntity::getUser).toList();
        if(CollectionUtils.isNotEmpty(userList)){
            userList=userList.stream().distinct().toList();
            map= signFacade.buildLaborContractProcessor(userList);
        }
        //拷贝对象
        List<UserStaffVo> targetList=new ArrayList<>(source.getSize());
        for (UserStaffEntity sourceEntity : sourceList) {
            UserStaffVo targetVo = new UserStaffVo();
            BeanUtils.copyProperties(sourceEntity,targetVo);
            targetVo.setLaborContractName(map.get(targetVo.getUser()));
            targetList.add(targetVo);
        }

        //搜索出所属劳动合同条件
        if(StringUtils.isNotBlank(staff.getLaborContract())){
            LaborContractEntity labor = laborRepository.findById(staff.getLaborContract()).get();
            List<UserStaffVo> list =targetList.stream()
                    .filter(item -> !labor.getName().equals(item.getLaborContractName()))
                    .toList();
            targetList.removeAll(list);
            targetTotal-=list.size();
        }
        Page<UserStaffVo> targetPage = new PageImpl<>(targetList,source.getPageable(),targetTotal);
        return targetPage;
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值