1、院系总积分功能开发

main
zhc077 1 year ago
parent 56b31b5863
commit ad2edd5d6e
  1. 7
      jeecg-boot-master/jeecg-module-demo/src/main/java/org/jeecg/modules/demo/annualScore/service/impl/DepartCompTotalScoreServiceImpl.java
  2. 170
      jeecg-boot-master/jeecg-module-demo/src/main/java/org/jeecg/modules/demo/annualScore/service/impl/PersonalCompScoreServiceImpl.java

@ -40,12 +40,11 @@ public class DepartCompTotalScoreServiceImpl extends ServiceImpl<DepartCompTotal
List<PersonalCompScore> personalCompScoreList = iPersonalCompScoreService.list(new LambdaQueryWrapper<PersonalCompScore>() List<PersonalCompScore> personalCompScoreList = iPersonalCompScoreService.list(new LambdaQueryWrapper<PersonalCompScore>()
.eq(PersonalCompScore::getAnnualId, departCompTotalScore.getAnnualId()) .eq(PersonalCompScore::getAnnualId, departCompTotalScore.getAnnualId())
.eq(PersonalCompScore::getDepet, departCompTotalScore.getDepet())); .eq(PersonalCompScore::getDepet, departCompTotalScore.getDepet())
);
double totalScore = 0; double totalScore = 0;
if (ObjectUtils.isEmpty(personalCompScoreList)) { if (!ObjectUtils.isEmpty(personalCompScoreList)) {
totalScore = 0;
} else {
totalScore = personalCompScoreList.stream().mapToDouble(PersonalCompScore::getScore).sum(); totalScore = personalCompScoreList.stream().mapToDouble(PersonalCompScore::getScore).sum();
} }
departCompTotalScore.setScore(totalScore); departCompTotalScore.setScore(totalScore);

@ -16,6 +16,8 @@ import org.jeecg.modules.demo.annualcompaward.entity.AnnualCompAward;
import org.jeecg.modules.demo.annualcompaward.service.IAnnualCompAwardService; import org.jeecg.modules.demo.annualcompaward.service.IAnnualCompAwardService;
import org.jeecg.modules.demo.annualcompetitionprojectregistration.entity.TeamManagement; import org.jeecg.modules.demo.annualcompetitionprojectregistration.entity.TeamManagement;
import org.jeecg.modules.demo.annualcompetitionprojectregistration.service.ITeamManagementService; import org.jeecg.modules.demo.annualcompetitionprojectregistration.service.ITeamManagementService;
import org.jeecg.modules.demo.awardpersion.entity.AwardPersion;
import org.jeecg.modules.demo.awardpersion.service.IAwardPersionService;
import org.jeecg.modules.demo.comp.entity.Comp; import org.jeecg.modules.demo.comp.entity.Comp;
import org.jeecg.modules.demo.comp.service.ICompService; import org.jeecg.modules.demo.comp.service.ICompService;
import org.jeecg.modules.system.entity.SysDepart; import org.jeecg.modules.system.entity.SysDepart;
@ -62,6 +64,9 @@ public class PersonalCompScoreServiceImpl extends ServiceImpl<PersonalCompScoreM
@Autowired @Autowired
private IPersonalCompTotalScoreService iPersonalCompTotalScoreService; private IPersonalCompTotalScoreService iPersonalCompTotalScoreService;
@Autowired
private IAwardPersionService iAwardPersionService;
private static final Integer ONE_HUNDRED = 100; private static final Integer ONE_HUNDRED = 100;
private static final Double ZERO_POINT_FIVE = 0.5; private static final Double ZERO_POINT_FIVE = 0.5;
private static final Double ZERO_POINT_TWO = 0.2; private static final Double ZERO_POINT_TWO = 0.2;
@ -74,9 +79,11 @@ public class PersonalCompScoreServiceImpl extends ServiceImpl<PersonalCompScoreM
//年度比赛id //年度比赛id
String annualCompId = personalCompScore.getAnnualCompId(); String annualCompId = personalCompScore.getAnnualCompId();
//年度比赛
AnnualComp annualComp = iAnnualCompService.getById(annualCompId); AnnualComp annualComp = iAnnualCompService.getById(annualCompId);
if (ObjectUtils.isEmpty(annualComp)) return; if (ObjectUtils.isEmpty(annualComp)) return;
//比赛
Comp comp = iCompService.getById(annualComp.getCompid()); Comp comp = iCompService.getById(annualComp.getCompid());
if (ObjectUtils.isEmpty(comp)) return; if (ObjectUtils.isEmpty(comp)) return;
//项目分值 //项目分值
@ -91,89 +98,93 @@ public class PersonalCompScoreServiceImpl extends ServiceImpl<PersonalCompScoreM
List<PersonalCompScore> saveList = new LinkedList<>(); List<PersonalCompScore> saveList = new LinkedList<>();
if (!ObjectUtils.isEmpty(annualCompPoint)) { if (!ObjectUtils.isEmpty(annualCompPoint)) {
//TODO
//1、根据年度比赛项目id,查询获取管理(award_persion)列表,即参赛人员及获取奖项顺序号 //1、根据年度比赛项目id,查询获取管理(award_persion)列表,即参赛人员及获取奖项顺序号
List<AwardPersion> awardPersionList = iAwardPersionService.list(new LambdaQueryWrapper<AwardPersion>()
.eq(AwardPersion::getAnnualCompP, annualCompPoint.getId()));
//2、遍历获奖理理(award_persion)列表,根据奖项id查询比赛奖项设置表(annual_comp_award) //2、遍历获奖理理(award_persion)列表,根据奖项id查询比赛奖项设置表(annual_comp_award)
//2.1、比赛奖项设置 根据awardsort奖项顺序,获取对应的奖项权重值 Optional.ofNullable(awardPersionList).orElse(new LinkedList<>()).forEach(en -> {
//奖项顺序与交期权重值映射关系: wardsort(1:first_weight,2:second_weight,3:third_weight,4:fourth_weight,5:fifth_weight
//2.1、比赛奖项设置 根据awardsort奖项顺序,获取对应的奖项权重值
//奖项顺序与奖项权重值映射关系: wardsort(1:first_weight,2:second_weight,3:third_weight,4:fourth_weight,5:fifth_weight
AnnualCompAward annualCompAward = iAnnualCompAwardService.getById("获奖理理表id"); AnnualCompAward annualCompAward = iAnnualCompAwardService.getById(en.getId());
if (ObjectUtils.isEmpty(annualCompAward)) return; if (ObjectUtils.isEmpty(annualCompAward)) return;
Integer wardsort = 0; //奖项权重值 百分比
//权重 百分比 String weightVal;
String weightVal; switch (en.getAwardsort()) {
switch (wardsort) { case 1:
case 1: weightVal = annualCompAward.getFifthWeight();
weightVal = annualCompAward.getFifthWeight(); break;
break; case 2:
case 2: weightVal = annualCompAward.getSecondWeight();
weightVal = annualCompAward.getSecondWeight(); break;
break; case 3:
case 3: weightVal = annualCompAward.getThirdWeight();
weightVal = annualCompAward.getThirdWeight(); break;
break; case 4:
case 4: weightVal = annualCompAward.getFourthWeight();
weightVal = annualCompAward.getFourthWeight(); break;
break; case 5:
case 5: weightVal = annualCompAward.getFifthWeight();
weightVal = annualCompAward.getFifthWeight(); break;
break; default:
default: weightVal = "100";
weightVal = "1"; }
} //参与形式 个人、团队,键值对 N-个人 Y-团队
String entryForm = annualCompPoint.getEntryForm(); String entryForm = annualCompPoint.getEntryForm();
List<TeamManagement> managementList = iTeamManagementService.list(new LambdaQueryWrapper<TeamManagement>()
.eq(TeamManagement::getEnrollCode, "获奖管理表enroll_code") //2.2 根据报名编号查询参赛者信息
); List<TeamManagement> managementList = iTeamManagementService.list(new LambdaQueryWrapper<TeamManagement>()
//参与形式 个人、团队,键值对 N-个人 Y-团队 .eq(TeamManagement::getEnrollCode, en.getEnrollCode())
//3、计算积分 );
double baseScore = ComputeUtils.mul(compweight_val, ComputeUtils.div2(new Double(weightVal), ONE_HUNDRED)); if (ObjectUtils.isEmpty(managementList)) return;
AtomicReference<Double> score = new AtomicReference<>((double) 0);
if (StringUtils.equals("Y", entryForm)) { //团队赛 //3、计算积分 项目分值*项目奖项权重值/100
Optional.ofNullable(managementList).orElse(new ArrayList<>()).forEach(e -> { double baseScore = ComputeUtils.mul(compweight_val, ComputeUtils.div2(new Double(weightVal), ONE_HUNDRED));
// 参与形式是团队时,队长积分*0.5,职员积分*0.2 AtomicReference<Double> score = new AtomicReference<>((double) 0);
//captain 是否队长,自关联表如果是队长则是为0.如果不是存储队长学号 if (StringUtils.equals("Y", entryForm)) { //团队赛
if (StringUtils.equals("0", e.getCaptain())) { Optional.ofNullable(managementList).orElse(new ArrayList<>()).forEach(e -> {
score.set(ComputeUtils.mul(baseScore, ZERO_POINT_FIVE)); // 参与形式是团队时,队长积分*0.5,职员积分*0.2
} else { //captain 是否队长
score.set(ComputeUtils.mul(baseScore, ZERO_POINT_TWO)); if (StringUtils.equals("0", e.getCaptain())) {
} score.set(ComputeUtils.mul(baseScore, ZERO_POINT_FIVE));
} else {
score.set(ComputeUtils.mul(baseScore, ZERO_POINT_TWO));
}
PersonalCompScore bean = new PersonalCompScore();
bean.setAnnualCompId(annualCompId);
bean.setAnnualCompP(annualCompPoint.getId());
bean.setAnnualId(annualComp.getAnnualid());
SysUser sysUser = iSysUserService.getById(e.getUserId());
bean.setWorkOn(sysUser.getWorkNo());
bean.setName(sysUser.getRealname());
SysDepart sysDepart = iSysDepartService.getById(sysUser.getOrgCode());
bean.setDepet(sysDepart.getId());
bean.setScore(score.get());
saveList.add(bean);
});
} else { //个人赛
score.set(baseScore);
TeamManagement teamManagement = managementList.get(0);
PersonalCompScore bean = new PersonalCompScore(); PersonalCompScore bean = new PersonalCompScore();
bean.setAnnualCompId(annualCompId); bean.setAnnualCompId(annualCompId);
bean.setAnnualCompP(annualCompPoint.getId()); bean.setAnnualCompP(annualCompPoint.getId());
bean.setAnnualId(annualComp.getAnnualid()); bean.setAnnualId(annualComp.getAnnualid());
SysUser sysUser = iSysUserService.getById(e.getUserId()); SysUser sysUser = iSysUserService.getById(teamManagement.getUserId());
bean.setWorkOn(sysUser.getWorkNo()); bean.setWorkOn(sysUser.getWorkNo());
bean.setName(sysUser.getRealname()); bean.setName(sysUser.getRealname());
SysDepart sysDepart = iSysDepartService.getById(sysUser.getOrgCode()); SysDepart sysDepart = iSysDepartService.getById(sysUser.getOrgCode());
bean.setDepet(sysDepart.getId()); bean.setDepet(sysDepart.getId());
bean.setScore(score.get()); bean.setScore(score.get());
saveList.add(bean); saveList.add(bean);
}); }
} else { //个人赛 });
score.set(baseScore);
TeamManagement teamManagement = managementList.get(0);
PersonalCompScore bean = new PersonalCompScore();
bean.setAnnualCompId(annualCompId);
bean.setAnnualCompP(annualCompPoint.getId());
bean.setAnnualId(annualComp.getAnnualid());
SysUser sysUser = iSysUserService.getById(teamManagement.getUserId());
bean.setWorkOn(sysUser.getWorkNo());
bean.setName(sysUser.getRealname());
SysDepart sysDepart = iSysDepartService.getById(sysUser.getOrgCode());
bean.setDepet(sysDepart.getId());
bean.setScore(score.get());
saveList.add(bean);
}
} }
this.saveBatch(saveList); this.saveBatch(saveList);
//个人比赛积分汇总完成,汇总个人总积分 //个人比赛积分汇总完成后,汇总个人总积分
this.iPersonalCompTotalScoreService.saveOrUpdateTotalScore(saveList); this.iPersonalCompTotalScoreService.saveOrUpdateTotalScore(saveList);
//更新状态为积分已汇总 //更新状态为积分已汇总
@ -183,31 +194,4 @@ public class PersonalCompScoreServiceImpl extends ServiceImpl<PersonalCompScoreM
.set(AnnualCompPoint::getAnnualCompState, 10) .set(AnnualCompPoint::getAnnualCompState, 10)
.update(); .update();
} }
/**
* 精确的乘法运算
*
* @param v1
* @param v2
* @return
*/
// public static double mul(double v1, double v2) {
// BigDecimal b1 = BigDecimal.valueOf(v1);
// BigDecimal b2 = BigDecimal.valueOf(v2);
// return b1.multiply(b2).doubleValue();
// }
//
// /**
// * @description: 提供(相对)精确的除法运算,当发生除不尽的情况时
// * 精确到小数点后10位的数字四舍五入
// * @param: [v1, v2]
// * @return: double
// * @author: z.h.c
// * @date: 23/11/1 08:41
// */
// public static double div(double v1, double v2) {
// BigDecimal b1 = BigDecimal.valueOf(v1);
// BigDecimal b2 = BigDecimal.valueOf(v2);
// return b1.divide(b2, 2, BigDecimal.ROUND_HALF_UP).doubleValue();
// }
} }

Loading…
Cancel
Save