BaseClassMergeServiceImpl.java 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195
  1. package com.xjrsoft.module.base.service.impl;
  2. import cn.dev33.satoken.stp.StpUtil;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  5. import com.github.yulichang.base.MPJBaseServiceImpl;
  6. import com.github.yulichang.wrapper.MPJLambdaWrapper;
  7. import com.xjrsoft.common.enums.DeleteMark;
  8. import com.xjrsoft.common.enums.StudentChangeTypeEnum;
  9. import com.xjrsoft.common.exception.MyException;
  10. import com.xjrsoft.common.page.ConventPage;
  11. import com.xjrsoft.common.utils.VoToColumnUtil;
  12. import com.xjrsoft.module.base.dto.BaseClassMergeStudentPageDto;
  13. import com.xjrsoft.module.base.entity.BaseClass;
  14. import com.xjrsoft.module.base.entity.BaseClassMerge;
  15. import com.xjrsoft.module.base.entity.BaseClassMergeStudent;
  16. import com.xjrsoft.module.base.mapper.BaseClassMapper;
  17. import com.xjrsoft.module.base.mapper.BaseClassMergeMapper;
  18. import com.xjrsoft.module.base.mapper.BaseClassMergeStudentMapper;
  19. import com.xjrsoft.module.base.service.IBaseClassMergeService;
  20. import com.xjrsoft.module.base.vo.BaseClassMergeStudentVo;
  21. import com.xjrsoft.module.organization.entity.User;
  22. import com.xjrsoft.module.student.entity.StudentChangeRecord;
  23. import com.xjrsoft.module.student.mapper.BaseStudentSchoolRollMapper;
  24. import com.xjrsoft.module.student.service.IStudentChangeRecordService;
  25. import com.xjrsoft.module.system.entity.DictionaryDetail;
  26. import lombok.AllArgsConstructor;
  27. import org.springframework.stereotype.Service;
  28. import org.springframework.transaction.annotation.Transactional;
  29. import java.util.ArrayList;
  30. import java.util.List;
  31. import java.util.Map;
  32. import java.util.Objects;
  33. import java.util.Set;
  34. import java.util.stream.Collectors;
  35. /**
  36. * @title: 班级合并
  37. * @Author dzx
  38. * @Date: 2025-04-08
  39. * @Version 1.0
  40. */
  41. @Service
  42. @AllArgsConstructor
  43. public class BaseClassMergeServiceImpl extends MPJBaseServiceImpl<BaseClassMergeMapper, BaseClassMerge> implements IBaseClassMergeService {
  44. private final BaseClassMergeStudentMapper mergeStudentMapper;
  45. private final BaseClassMapper baseClassMapper;
  46. private final BaseStudentSchoolRollMapper schoolRollMapper;
  47. private final IStudentChangeRecordService changeRecordService;
  48. @Override
  49. @Transactional(rollbackFor = Exception.class)
  50. public Boolean add(BaseClassMerge baseClassMerge) {
  51. Set<Long> collect = baseClassMerge.getBaseClassMergeStudentList().stream().map(BaseClassMergeStudent::getClassId).collect(Collectors.toSet());
  52. if(collect.contains(baseClassMerge.getTargetClassId())){
  53. throw new MyException("原有班级中不能包含目标班级,请重新选择原有班级");
  54. }
  55. baseClassMerge.setStudentCount(baseClassMerge.getBaseClassMergeStudentList().size());
  56. this.baseMapper.insert(baseClassMerge);
  57. BaseClass baseClass = baseClassMapper.selectById(baseClassMerge.getTargetClassId());
  58. List<BaseClass> classList = baseClassMapper.selectBatchIds(collect);
  59. Map<Long, String> classMap = classList.stream().collect(Collectors.toMap(BaseClass::getId, BaseClass::getName));
  60. for (BaseClassMergeStudent baseClassMergeStudent : baseClassMerge.getBaseClassMergeStudentList()) {
  61. baseClassMergeStudent.setBaseClassMergeId(baseClassMerge.getId());
  62. mergeStudentMapper.insert(baseClassMergeStudent);
  63. schoolRollMapper.updateStudentClass(baseClass.getId(), baseClass.getGradeId(), baseClass.getMajorSetId(), baseClassMergeStudent.getUserId());
  64. changeRecordService.insertData(
  65. classMap.get(baseClassMergeStudent.getClassId()),
  66. baseClassMergeStudent.getClassId().toString(),
  67. baseClass.getName(),
  68. baseClass.getId().toString(),
  69. baseClassMergeStudent.getUserId(),
  70. StpUtil.getLoginIdAsLong(),
  71. StudentChangeTypeEnum.ChangeClass.getCode(),
  72. 3
  73. );
  74. }
  75. return true;
  76. }
  77. @Override
  78. @Transactional(rollbackFor = Exception.class)
  79. public Boolean update(BaseClassMerge baseClassMerge) {
  80. this.baseMapper.updateById(baseClassMerge);
  81. //********************************* BaseClassMergeStudent 增删改 开始 *******************************************/
  82. {
  83. // 查出所有子级的id
  84. List<BaseClassMergeStudent> baseClassMergeStudentList = mergeStudentMapper.selectList(Wrappers.lambdaQuery(BaseClassMergeStudent.class).eq(BaseClassMergeStudent::getBaseClassMergeId, baseClassMerge.getId()).select(BaseClassMergeStudent::getId));
  85. List<Long> baseClassMergeStudentIds = baseClassMergeStudentList.stream().map(BaseClassMergeStudent::getId).collect(Collectors.toList());
  86. //原有子表单 没有被删除的主键
  87. List<Long> baseClassMergeStudentOldIds = baseClassMerge.getBaseClassMergeStudentList().stream().map(BaseClassMergeStudent::getId).filter(Objects::nonNull).collect(Collectors.toList());
  88. //找到需要删除的id
  89. List<Long> baseClassMergeStudentRemoveIds = baseClassMergeStudentIds.stream().filter(item -> !baseClassMergeStudentOldIds.contains(item)).collect(Collectors.toList());
  90. for (BaseClassMergeStudent baseClassMergeStudent : baseClassMerge.getBaseClassMergeStudentList()) {
  91. //如果不等于空则修改
  92. if (baseClassMergeStudent.getId() != null) {
  93. mergeStudentMapper.updateById(baseClassMergeStudent);
  94. }
  95. //如果等于空 则新增
  96. else {
  97. //已经不存在的id 删除
  98. baseClassMergeStudent.setBaseClassMergeId(baseClassMerge.getId());
  99. mergeStudentMapper.insert(baseClassMergeStudent);
  100. }
  101. }
  102. //已经不存在的id 删除
  103. if(!baseClassMergeStudentRemoveIds.isEmpty()){
  104. mergeStudentMapper.deleteBatchIds(baseClassMergeStudentRemoveIds);
  105. }
  106. }
  107. //********************************* BaseClassMergeStudent 增删改 结束 *******************************************/
  108. return true;
  109. }
  110. @Override
  111. @Transactional(rollbackFor = Exception.class)
  112. public Boolean delete(List<Long> ids) {
  113. this.baseMapper.deleteBatchIds(ids);
  114. mergeStudentMapper.delete(Wrappers.lambdaQuery(BaseClassMergeStudent.class).in(BaseClassMergeStudent::getBaseClassMergeId, ids));
  115. return true;
  116. }
  117. @Override
  118. public List<BaseClass> getClassListByMergeId(Long id) {
  119. List<BaseClass> classList = baseClassMapper.selectList(
  120. new MPJLambdaWrapper<BaseClass>()
  121. .select(BaseClass::getId)
  122. .select(BaseClass.class, x -> VoToColumnUtil.fieldsToColumns(BaseClass.class).contains(x.getProperty()))
  123. .innerJoin(BaseClassMergeStudent.class, BaseClassMergeStudent::getClassId, BaseClass::getId)
  124. .eq(BaseClassMergeStudent::getDeleteMark, DeleteMark.NODELETE.getCode())
  125. .eq(BaseClassMergeStudent::getBaseClassMergeId, id)
  126. .orderByAsc(BaseClass::getName)
  127. );
  128. return classList;
  129. }
  130. @Override
  131. public String getClassNamesByMergeId(Long id) {
  132. List<BaseClass> classList = getClassListByMergeId(id);
  133. if(!classList.isEmpty()){
  134. Set<String> classNameSet = classList.stream().map(BaseClass::getName).collect(Collectors.toSet());
  135. return classNameSet.toString().replace("[", "").replace("]", "").replace(" ", "");
  136. }
  137. return null;
  138. }
  139. @Override
  140. public IPage<BaseClassMergeStudentVo> getStudentPage(BaseClassMergeStudentPageDto dto) {
  141. MPJLambdaWrapper<BaseClassMergeStudent> queryWrapper = new MPJLambdaWrapper<>();
  142. queryWrapper
  143. .select(BaseClassMergeStudent::getId)
  144. .select(BaseClassMergeStudent.class,x -> VoToColumnUtil.fieldsToColumns(BaseClassMergeStudent.class).contains(x.getProperty()))
  145. .selectAs(BaseClass::getName, BaseClassMergeStudentVo::getClassName)
  146. .selectAs(User::getName, BaseClassMergeStudentVo::getName)
  147. .selectAs(User::getCredentialNumber, BaseClassMergeStudentVo::getCredentialNumber)
  148. .select("t4.name", BaseClassMergeStudentVo::getGender)
  149. .select("t3.name", BaseClassMergeStudentVo::getTeacherName)
  150. .innerJoin(User.class, User::getId, BaseClassMergeStudent::getUserId)
  151. .innerJoin(BaseClass.class, BaseClass::getId, BaseClassMergeStudent::getClassId)
  152. .leftJoin(User.class, User::getId, BaseClass::getTeacherId)
  153. .innerJoin("xjr_dictionary_detail t4 ON (t4.code = t1.gender) ")
  154. .eq(BaseClassMergeStudent::getBaseClassMergeId, dto.getBaseClassMergeId())
  155. .orderByDesc(BaseClassMergeStudent::getId);
  156. IPage<BaseClassMergeStudentVo> page = mergeStudentMapper.selectJoinPage(ConventPage.getPage(dto), BaseClassMergeStudentVo.class, queryWrapper);
  157. return page;
  158. }
  159. @Override
  160. public List<Long> getClassIdsByClassName(String className) {
  161. List<BaseClassMergeStudent> classList = mergeStudentMapper.selectList(
  162. new MPJLambdaWrapper<BaseClassMergeStudent>()
  163. .distinct()
  164. .select(BaseClassMergeStudent::getId)
  165. .select(BaseClassMergeStudent.class, x -> VoToColumnUtil.fieldsToColumns(BaseClassMergeStudent.class).contains(x.getProperty()))
  166. .innerJoin(BaseClass.class, BaseClass::getId, BaseClassMergeStudent::getClassId)
  167. .eq(BaseClassMergeStudent::getDeleteMark, DeleteMark.NODELETE.getCode())
  168. .like(BaseClass::getName, className)
  169. );
  170. if(!classList.isEmpty()){
  171. Set<Long> collect = classList.stream().map(BaseClassMergeStudent::getBaseClassMergeId).collect(Collectors.toSet());
  172. return new ArrayList<>(collect);
  173. }
  174. return null;
  175. }
  176. }