diff --git a/pom.xml b/pom.xml index 1f52a11..1ac3f4e 100644 --- a/pom.xml +++ b/pom.xml @@ -35,7 +35,10 @@ spring-test 5.1.5.RELEASE - + + org.springframework.boot + spring-boot-starter-validation + org.apache.poi poi diff --git a/src/main/java/com/teaching/backend/model/entity/chapter/Chapter.java b/src/main/java/com/teaching/backend/model/entity/chapter/Chapter.java index 9a2f6f6..7e80163 100644 --- a/src/main/java/com/teaching/backend/model/entity/chapter/Chapter.java +++ b/src/main/java/com/teaching/backend/model/entity/chapter/Chapter.java @@ -71,9 +71,7 @@ public class Chapter implements Serializable { private String courseObjectivesId; @ApiModelProperty(value = "总学时") - //使用参数合法性校验 @Digits(integer = 10, fraction = 1, message = "总学时只能保留一位小数") -// package com.teaching.backend.exception;需要在这个里面添加异常处理 private double totalClassHours; @ApiModelProperty(value = "要求") diff --git a/src/main/java/com/teaching/backend/service/impl/chapter/ChapterServiceImpl.java b/src/main/java/com/teaching/backend/service/impl/chapter/ChapterServiceImpl.java index 8ce1301..db393d3 100644 --- a/src/main/java/com/teaching/backend/service/impl/chapter/ChapterServiceImpl.java +++ b/src/main/java/com/teaching/backend/service/impl/chapter/ChapterServiceImpl.java @@ -244,8 +244,9 @@ public class ChapterServiceImpl extends ServiceImpl impl BigDecimal remainingHours = BigDecimal.ZERO; // 初始化剩余学时 - if (pid == null) { + if (pid == null||pid.equals(0L)) { BigDecimal classHours = coursesMapper.getClassHoursById(chapterDTO.getCourseId()); + LambdaQueryWrapper lambdaQueryWrapper = new LambdaQueryWrapper<>(); lambdaQueryWrapper.eq(Chapter::getPid, 0) .eq(Chapter::getCourseId, chapterDTO.getCourseId()); @@ -258,10 +259,10 @@ public class ChapterServiceImpl extends ServiceImpl impl .reduce(BigDecimal.ZERO, BigDecimal::add); remainingHours = classHours.subtract(totalChapterHours).setScale(1, RoundingMode.HALF_UP); + BigDecimal newChapterHours = BigDecimal.valueOf(chapter.getTotalClassHours()); // 根据实际返回类型调整 - - if (totalChapterHours.compareTo(classHours) < 0) { + if (newChapterHours.compareTo(remainingHours) <= 0) { chapter.setPid(0L); LambdaQueryWrapper maxSortWrapper = new LambdaQueryWrapper<>(); maxSortWrapper.eq(Chapter::getPid, 0).orderByDesc(Chapter::getOrderNum).last("limit 1"); @@ -274,10 +275,12 @@ public class ChapterServiceImpl extends ServiceImpl impl chapter.setCreateTime(LocalDateTime.now()); chapter.setUpdateTime(LocalDateTime.now()); this.save(chapter); + remainingHours = remainingHours.subtract(newChapterHours).setScale(1, RoundingMode.HALF_UP); } else { - throw new BusinessException(ErrorCode.PARAMS_ERROR, "当前课程的总学时已经分配完成,请先修改章节学时,或者课程总学时"); + throw new BusinessException(ErrorCode.PARAMS_ERROR, "当前添加的学时为:"+newChapterHours+"当前剩余学时为:"+remainingHours); } - } else { + } + else { BigDecimal chapterHours = chapterMapper.getChapterHours(pid); @@ -297,7 +300,6 @@ public class ChapterServiceImpl extends ServiceImpl impl - remainingHours = chapterHours.subtract(hours).setScale(1, RoundingMode.HALF_UP);