BaseClassMergeServiceImpl.java 8.8 KB

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