From 26474b4765a4d0ed9be06c03adba4c9039ed8a4d Mon Sep 17 00:00:00 2001 From: arybakov Date: Fri, 20 Sep 2024 16:42:57 -0600 Subject: [PATCH] GRAD2-2971 Student Archive for one school needs to be able to handle > 1000 students --- .../gradstudent/service/HistoryService.java | 23 ++++++++++++------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/api/src/main/java/ca/bc/gov/educ/api/gradstudent/service/HistoryService.java b/api/src/main/java/ca/bc/gov/educ/api/gradstudent/service/HistoryService.java index 251fc456..b3529ea1 100644 --- a/api/src/main/java/ca/bc/gov/educ/api/gradstudent/service/HistoryService.java +++ b/api/src/main/java/ca/bc/gov/educ/api/gradstudent/service/HistoryService.java @@ -26,10 +26,7 @@ import org.springframework.transaction.annotation.Transactional; import org.springframework.web.reactive.function.client.WebClient; -import java.util.List; -import java.util.Objects; -import java.util.Optional; -import java.util.UUID; +import java.util.*; @Service public class HistoryService { @@ -164,11 +161,21 @@ public Page getStudentHistoryByBatchID(Lon @Transactional public Integer updateStudentRecordHistoryDistributionRun(Long batchId, String updateUser, String activityCode, List studentGuids) { - Integer historyRecordsCreated; + Integer historyRecordsCreated = 0; if(studentGuids != null && !studentGuids.isEmpty()) { - Integer studentRecordsCreated = graduationStatusRepository.updateGraduationStudentRecordEntitiesBatchIdWhereStudentIDsIn(batchId, studentGuids); - historyRecordsCreated = graduationStudentRecordHistoryRepository.insertGraduationStudentRecordHistoryByBatchIdAndStudentIDs(batchId, studentGuids, activityCode, updateUser); - assert Objects.equals(studentRecordsCreated, historyRecordsCreated); + int partitionSize = 999; + List> partitions = new LinkedList<>(); + for (int i = 0; i < studentGuids.size(); i += partitionSize) { + partitions.add(studentGuids.subList(i, Math.min(i + partitionSize, studentGuids.size()))); + } + logger.debug("Update Student Record History partitions length {}", partitions.size()); + for (int i = 0; i < partitions.size(); i++) { + List subList = partitions.get(i); + Integer studentRecordsCreatedPartition = graduationStatusRepository.updateGraduationStudentRecordEntitiesBatchIdWhereStudentIDsIn(batchId, subList); + Integer historyRecordsCreatedPartition = graduationStudentRecordHistoryRepository.insertGraduationStudentRecordHistoryByBatchIdAndStudentIDs(batchId, subList, activityCode, updateUser); + assert Objects.equals(studentRecordsCreatedPartition, historyRecordsCreatedPartition); + historyRecordsCreated += historyRecordsCreatedPartition; + } } else if(StringUtils.equalsIgnoreCase(activityCode, "USERSTUDARC")) { historyRecordsCreated = graduationStudentRecordHistoryRepository.insertGraduationStudentRecordHistoryByBatchId(batchId, activityCode, updateUser); } else if(StringUtils.isBlank(activityCode) || StringUtils.equalsIgnoreCase(activityCode, "null")) {