Java Mybatis plus 语法中 避免sql循环

1. 查出全部数据并进行数据筛选过滤

在一对多的情况时,我们想把多的对象集合set进一的里面,需要避免循环sql

java 复制代码
    @Override
    public R<List<ExRecord>> getExRecordAll(ExRecord exRecord) {

        // 获取用户id
        Integer userId = Math.toIntExact(SecurityUtils.getUserId());



        List<ExRecord> exRecords = exRecordMapper.selectList(new LambdaQueryWrapper<ExRecord>()
                // 根据用户id
                .eq(Objects.nonNull(userId), ExRecord::getUserId, userId)
                // 根据 试卷类型
                .eq(Objects.nonNull(exRecord.getPaperType()), ExRecord::getPaperType, exRecord.getPaperType())
        );

          // 过滤出全部id
        List<Integer> recordIds = exRecords.stream().map(ExRecord::getId).collect(Collectors.toList());

        // 过滤答题卡表中的id,并stream流进行分组
        Map<Integer, List<ExSheetAnswer>> collect = examSheetAnswerMapper.selectList(Wrappers.<ExSheetAnswer>lambdaQuery()
                .in(ExSheetAnswer::getRecordId, recordIds)).stream().collect(Collectors.groupingBy(ExSheetAnswer::getRecordId));

        // 根据map id 去赋值
        exRecords.forEach(record -> {
            record.setSheetAnswers(collect.getOrDefault(record.getId(), Collections.emptyList()));
        });


        return R.success(exRecords);
    }
相关推荐
百***49002 分钟前
SpringSecurity的配置
java
@老蝴25 分钟前
Java EE - 常见的死锁和解决方法
java·开发语言·java-ee
wangmengxxw32 分钟前
Swagger技术
java·swagger
l1t1 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
全干engineer1 小时前
idea拉取github代码 -TLS connect error 异常问题
java·github·intellij-idea
10岁的博客1 小时前
二维差分算法高效解靶场问题
java·服务器·算法
百***93501 小时前
Tomcat报404问题解决方案大全(包括tomcat可以正常运行但是报404)
java·tomcat
百***81271 小时前
Spring 中使用Mybatis,超详细
spring·tomcat·mybatis
qq_281317471 小时前
kubernetes(k8s)-pod生命周期
java·容器·kubernetes
IT界的奇葩2 小时前
代码规范 spring-javaformat使用
java·spring·代码规范