修正考核问题查询的sql
parent
7bc6712180
commit
97632ce613
|
|
@ -56,7 +56,7 @@ public interface AssessTeamRatingMapper extends BaseMapper<AssessTeamRating> {
|
||||||
left join public.assess_task t5 on t1.task_id = t5.id
|
left join public.assess_task t5 on t1.task_id = t5.id
|
||||||
where t.is_need_rectify = 1 and t5.status = 3
|
where t.is_need_rectify = 1 and t5.status = 3
|
||||||
<if test="obj.userId != null">
|
<if test="obj.userId != null">
|
||||||
and t.object_id = #{obj.userId}
|
and t2.object_user_id = #{obj.userId}
|
||||||
</if>
|
</if>
|
||||||
<if test="obj.taskName != null and obj.taskName != ''">
|
<if test="obj.taskName != null and obj.taskName != ''">
|
||||||
and t5.task_name like concat('%', #{obj.taskName}::text, '%')
|
and t5.task_name like concat('%', #{obj.taskName}::text, '%')
|
||||||
|
|
|
||||||
|
|
@ -12,8 +12,14 @@ import com.gunshi.project.xyt.entity.vo.AssessRectifyVo;
|
||||||
import com.gunshi.project.xyt.entity.vo.AssessScoreVo;
|
import com.gunshi.project.xyt.entity.vo.AssessScoreVo;
|
||||||
import com.gunshi.project.xyt.mapper.*;
|
import com.gunshi.project.xyt.mapper.*;
|
||||||
import com.gunshi.project.xyt.model.*;
|
import com.gunshi.project.xyt.model.*;
|
||||||
|
import com.ruoyi.common.core.domain.entity.SysUser;
|
||||||
|
import com.ruoyi.common.core.domain.model.LoginUser;
|
||||||
|
import com.ruoyi.common.utils.SecurityUtils;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.security.core.Authentication;
|
||||||
|
import org.springframework.security.core.context.SecurityContext;
|
||||||
|
import org.springframework.security.core.context.SecurityContextHolder;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
import org.springframework.transaction.annotation.Transactional;
|
import org.springframework.transaction.annotation.Transactional;
|
||||||
|
|
||||||
|
|
@ -33,8 +39,7 @@ import java.util.stream.Collectors;
|
||||||
@Service
|
@Service
|
||||||
@Slf4j
|
@Slf4j
|
||||||
@Transactional(rollbackFor = Exception.class)
|
@Transactional(rollbackFor = Exception.class)
|
||||||
public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper, AssessTeamRating>
|
public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper, AssessTeamRating> {
|
||||||
{
|
|
||||||
@Autowired
|
@Autowired
|
||||||
private FileAssociationsService fileService;
|
private FileAssociationsService fileService;
|
||||||
|
|
||||||
|
|
@ -57,17 +62,17 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
private AssessIndicatorRatingService indicatorRatingService;
|
private AssessIndicatorRatingService indicatorRatingService;
|
||||||
|
|
||||||
public Boolean saveScore(AssessScoreVo vo) {
|
public Boolean saveScore(AssessScoreVo vo) {
|
||||||
return commonScore(vo,9);
|
return commonScore(vo, 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Boolean commonScore(AssessScoreVo vo,Integer status){
|
private Boolean commonScore(AssessScoreVo vo, Integer status) {
|
||||||
List<AssessTeamRating> ratings = vo.getRatings();
|
List<AssessTeamRating> ratings = vo.getRatings();
|
||||||
Long teamId = ratings.get(0).getTeamId();
|
Long teamId = ratings.get(0).getTeamId();
|
||||||
this.delData(teamId);
|
this.delData(teamId);
|
||||||
for(AssessTeamRating rating : ratings){
|
for (AssessTeamRating rating : ratings) {
|
||||||
rating.setId(IdWorker.getId());
|
rating.setId(IdWorker.getId());
|
||||||
rating.setRectifyStatus(0);
|
rating.setRectifyStatus(0);
|
||||||
fileService.save(rating.getFiles(), rating.getId().toString(), getGroupId(),getScoreType());
|
fileService.save(rating.getFiles(), rating.getId().toString(), getGroupId(), getScoreType());
|
||||||
}
|
}
|
||||||
AssessTask task = taskMapper.selectById(vo.getTaskId());
|
AssessTask task = taskMapper.selectById(vo.getTaskId());
|
||||||
//更新该考核人员对考核对象的状态为已评分
|
//更新该考核人员对考核对象的状态为已评分
|
||||||
|
|
@ -76,26 +81,26 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
//获取模板信息
|
//获取模板信息
|
||||||
AssessTemplate template = templateMapper.selectById(task.getTemplateId());
|
AssessTemplate template = templateMapper.selectById(task.getTemplateId());
|
||||||
//根据总得分计算等级
|
//根据总得分计算等级
|
||||||
Integer level = calcLevel(template,vo.getScore());
|
Integer level = calcLevel(template, vo.getScore());
|
||||||
assessTeam.setAssessScore(vo.getScore());
|
assessTeam.setAssessScore(vo.getScore());
|
||||||
assessTeam.setAssessLevel(level);
|
assessTeam.setAssessLevel(level);
|
||||||
teamMapper.updateById(assessTeam);
|
teamMapper.updateById(assessTeam);
|
||||||
Boolean res = this.saveBatch(ratings);
|
Boolean res = this.saveBatch(ratings);
|
||||||
if(status == 2){
|
if (status == 2) {
|
||||||
updateObjectAndTask(assessTeam.getObjectId(),vo.getTaskId(),template,task);
|
updateObjectAndTask(assessTeam.getObjectId(), vo.getTaskId(), template, task);
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Boolean score(AssessScoreVo vo) {
|
public Boolean score(AssessScoreVo vo) {
|
||||||
return commonScore(vo,2);
|
return commonScore(vo, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void delData(Long teamId) {
|
private void delData(Long teamId) {
|
||||||
List<AssessTeamRating> teamRatings = this.list(new QueryWrapper<AssessTeamRating>().eq("team_id", teamId));
|
List<AssessTeamRating> teamRatings = this.list(new QueryWrapper<AssessTeamRating>().eq("team_id", teamId));
|
||||||
if(CollectionUtils.isNotEmpty(teamRatings)){
|
if (CollectionUtils.isNotEmpty(teamRatings)) {
|
||||||
List<String> ratingIds = teamRatings.stream().map(AssessTeamRating::getId).map(Objects::toString).collect(Collectors.toList());
|
List<String> ratingIds = teamRatings.stream().map(AssessTeamRating::getId).map(Objects::toString).collect(Collectors.toList());
|
||||||
fileService.remove(new QueryWrapper<FileAssociations>().in("business_id",ratingIds));
|
fileService.remove(new QueryWrapper<FileAssociations>().in("business_id", ratingIds));
|
||||||
this.remove(new QueryWrapper<AssessTeamRating>().eq("team_id", teamId));
|
this.remove(new QueryWrapper<AssessTeamRating>().eq("team_id", teamId));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
@ -104,26 +109,26 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
BigDecimal excellentScore = template.getExcellentScore();
|
BigDecimal excellentScore = template.getExcellentScore();
|
||||||
BigDecimal goodScore = template.getGoodScore();
|
BigDecimal goodScore = template.getGoodScore();
|
||||||
BigDecimal passScore = template.getPassScore();
|
BigDecimal passScore = template.getPassScore();
|
||||||
if(score.compareTo(excellentScore) >= 0){
|
if (score.compareTo(excellentScore) >= 0) {
|
||||||
return 1;
|
return 1;
|
||||||
}else if(score.compareTo(goodScore) >=0 && score.compareTo(excellentScore) < 0){
|
} else if (score.compareTo(goodScore) >= 0 && score.compareTo(excellentScore) < 0) {
|
||||||
return 2;
|
return 2;
|
||||||
}else if(score.compareTo(passScore) >=0 && score.compareTo(goodScore) < 0){
|
} else if (score.compareTo(passScore) >= 0 && score.compareTo(goodScore) < 0) {
|
||||||
return 3;
|
return 3;
|
||||||
}else{
|
} else {
|
||||||
return 4;
|
return 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateObjectAndTask(Long objectId, Long taskId,AssessTemplate template,AssessTask task) {
|
private void updateObjectAndTask(Long objectId, Long taskId, AssessTemplate template, AssessTask task) {
|
||||||
//先判断该次评分是否是该考核对象的最后一次评分
|
//先判断该次评分是否是该考核对象的最后一次评分
|
||||||
//如果为最后一次评分,就要计算该考核对象的最终得分
|
//如果为最后一次评分,就要计算该考核对象的最终得分
|
||||||
List<AssessTeam> teams = teamMapper.selectList(new QueryWrapper<AssessTeam>().eq("object_id", objectId).eq("task_id", taskId));
|
List<AssessTeam> teams = teamMapper.selectList(new QueryWrapper<AssessTeam>().eq("object_id", objectId).eq("task_id", taskId));
|
||||||
List<AssessTeam> finishTeams = teams.stream().filter(o -> o.getStatus() == 2).collect(Collectors.toList());
|
List<AssessTeam> finishTeams = teams.stream().filter(o -> o.getStatus() == 2).collect(Collectors.toList());
|
||||||
if(teams.size() == finishTeams.size()){
|
if (teams.size() == finishTeams.size()) {
|
||||||
Integer scoreWay = task.getScoreWay();
|
Integer scoreWay = task.getScoreWay();
|
||||||
List<Long> teamIds = finishTeams.stream().map(AssessTeam::getId).collect(Collectors.toList());
|
List<Long> teamIds = finishTeams.stream().map(AssessTeam::getId).collect(Collectors.toList());
|
||||||
BigDecimal assessScore = calcScore(scoreWay,teamIds,objectId);
|
BigDecimal assessScore = calcScore(scoreWay, teamIds, objectId);
|
||||||
Integer level = calcLevel(template, assessScore);
|
Integer level = calcLevel(template, assessScore);
|
||||||
AssessObject object = objectMapper.selectById(objectId);
|
AssessObject object = objectMapper.selectById(objectId);
|
||||||
object.setStatus(2);
|
object.setStatus(2);
|
||||||
|
|
@ -132,32 +137,32 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
objectMapper.updateById(object);
|
objectMapper.updateById(object);
|
||||||
//判断该考核任务是否存在未打分的对象,不存在则更新考核任务的状态为已完成
|
//判断该考核任务是否存在未打分的对象,不存在则更新考核任务的状态为已完成
|
||||||
Long taskCount = objectMapper.selectCount(new QueryWrapper<AssessObject>().eq("task_id", taskId).eq("status", 1));
|
Long taskCount = objectMapper.selectCount(new QueryWrapper<AssessObject>().eq("task_id", taskId).eq("status", 1));
|
||||||
if(taskCount == 0){
|
if (taskCount == 0) {
|
||||||
task.setStatus(2);
|
task.setStatus(2);
|
||||||
taskMapper.updateById(task);
|
taskMapper.updateById(task);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private BigDecimal calcScore(Integer scoreWay, List<Long> teamIds,Long objectId) {
|
private BigDecimal calcScore(Integer scoreWay, List<Long> teamIds, Long objectId) {
|
||||||
assessObjectRatingService.remove(new QueryWrapper<AssessObjectRating>().eq("object_id",objectId));
|
assessObjectRatingService.remove(new QueryWrapper<AssessObjectRating>().eq("object_id", objectId));
|
||||||
final BigDecimal[] score = {new BigDecimal(0)};
|
final BigDecimal[] score = {new BigDecimal(0)};
|
||||||
List<AssessTeamRating> ratings = this.list(new QueryWrapper<AssessTeamRating>().in("team_id",teamIds));
|
List<AssessTeamRating> ratings = this.list(new QueryWrapper<AssessTeamRating>().in("team_id", teamIds));
|
||||||
Map<Long, List<BigDecimal>> map = ratings.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId,Collectors.mapping(AssessTeamRating::getAssessScore,Collectors.toList())));
|
Map<Long, List<BigDecimal>> map = ratings.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId, Collectors.mapping(AssessTeamRating::getAssessScore, Collectors.toList())));
|
||||||
Map<Long, List<Integer>> standardMap = ratings.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId,Collectors.mapping(AssessTeamRating::getStandardScore,Collectors.toList())));
|
Map<Long, List<Integer>> standardMap = ratings.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId, Collectors.mapping(AssessTeamRating::getStandardScore, Collectors.toList())));
|
||||||
List<AssessObjectRating> list = new ArrayList<>();
|
List<AssessObjectRating> list = new ArrayList<>();
|
||||||
map.entrySet().forEach(o->{
|
map.entrySet().forEach(o -> {
|
||||||
List<BigDecimal> value = o.getValue();
|
List<BigDecimal> value = o.getValue();
|
||||||
AssessObjectRating objectRating = new AssessObjectRating();
|
AssessObjectRating objectRating = new AssessObjectRating();
|
||||||
objectRating.setId(IdWorker.getId());
|
objectRating.setId(IdWorker.getId());
|
||||||
objectRating.setObjectId(objectId);
|
objectRating.setObjectId(objectId);
|
||||||
objectRating.setIndicatorId(o.getKey());
|
objectRating.setIndicatorId(o.getKey());
|
||||||
objectRating.setStandardScore(standardMap.get(o.getKey()).get(0));
|
objectRating.setStandardScore(standardMap.get(o.getKey()).get(0));
|
||||||
if (scoreWay == 1){
|
if (scoreWay == 1) {
|
||||||
BigDecimal val = value.stream().min(BigDecimal::compareTo).get();
|
BigDecimal val = value.stream().min(BigDecimal::compareTo).get();
|
||||||
objectRating.setAssessScore(val);
|
objectRating.setAssessScore(val);
|
||||||
score[0] = score[0].add(val);
|
score[0] = score[0].add(val);
|
||||||
}else{
|
} else {
|
||||||
BigDecimal vide = value.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(value.size()), 2, RoundingMode.HALF_UP);
|
BigDecimal vide = value.stream().reduce(BigDecimal.ZERO, BigDecimal::add).divide(BigDecimal.valueOf(value.size()), 2, RoundingMode.HALF_UP);
|
||||||
objectRating.setAssessScore(vide);
|
objectRating.setAssessScore(vide);
|
||||||
score[0] = score[0].add(vide);
|
score[0] = score[0].add(vide);
|
||||||
|
|
@ -168,7 +173,7 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
return score[0];
|
return score[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
public void saveObjectRating(List<AssessObjectRating> list){
|
public void saveObjectRating(List<AssessObjectRating> list) {
|
||||||
assessObjectRatingService.saveBatch(list);
|
assessObjectRatingService.saveBatch(list);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -191,30 +196,41 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public Map<Long, List<AssessRatingVo>> scoreDetail(Long objectId) {
|
||||||
public Map<Long,List<AssessRatingVo>> scoreDetail(Long objectId) {
|
|
||||||
List<AssessRatingVo> list = this.baseMapper.scoreByObjectId(objectId);
|
List<AssessRatingVo> list = this.baseMapper.scoreByObjectId(objectId);
|
||||||
fillRating(list);
|
fillRating(list);
|
||||||
return list.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId));
|
return list.stream().collect(Collectors.groupingBy(AssessTeamRating::getIndicatorId));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void fillRating(List<AssessRatingVo> list){
|
private void fillRating(List<AssessRatingVo> list) {
|
||||||
List<AssessIndicatorRating> relList = indicatorRatingService.queryRatingList(list.stream().map(AssessRatingVo::getIndicatorId).distinct().collect(Collectors.toList()));
|
List<AssessIndicatorRating> relList = indicatorRatingService.queryRatingList(list.stream().map(AssessRatingVo::getIndicatorId).distinct().collect(Collectors.toList()));
|
||||||
Map<Long, List<AssessIndicatorRating>> map = relList.stream().collect(Collectors.groupingBy(AssessIndicatorRating::getIndicatorId));
|
Map<Long, List<AssessIndicatorRating>> map = relList.stream().collect(Collectors.groupingBy(AssessIndicatorRating::getIndicatorId));
|
||||||
for (AssessRatingVo vo : list){
|
for (AssessRatingVo vo : list) {
|
||||||
vo.setIndicatorRatings(map.get(vo.getIndicatorId()));
|
vo.setIndicatorRatings(map.get(vo.getIndicatorId()));
|
||||||
if(vo.getIsNeedRectify() != null && vo.getIsNeedRectify() == 1){
|
if (vo.getIsNeedRectify() != null && vo.getIsNeedRectify() == 1) {
|
||||||
vo.setFiles(fileService.queryFileList(vo.getId().toString(),getGroupId(),getScoreType()));
|
vo.setFiles(fileService.queryFileList(vo.getId().toString(), getGroupId(), getScoreType()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Page<AssessRectifyVo> listPage(AssessTaskPageSo page) {
|
public Page<AssessRectifyVo> listPage(AssessTaskPageSo page) {
|
||||||
|
/* 若以后需要根据当前登录人查询,则取消注释
|
||||||
|
SecurityContext context = SecurityContextHolder.getContext();
|
||||||
|
Authentication auth = context.getAuthentication();
|
||||||
|
Object principal = auth.getPrincipal();
|
||||||
|
log.info("principal is {}", principal);
|
||||||
|
LoginUser loginUser = (LoginUser) principal;
|
||||||
|
SysUser user = loginUser.getUser();
|
||||||
|
boolean admin = SecurityUtils.isAdmin(user.getUserId());
|
||||||
|
if (!admin) {
|
||||||
|
page.setUserId(user.getUserId());
|
||||||
|
}
|
||||||
|
*/
|
||||||
Page<AssessRectifyVo> res = this.baseMapper.listPage(page.getPageSo().toPage(), page);
|
Page<AssessRectifyVo> res = this.baseMapper.listPage(page.getPageSo().toPage(), page);
|
||||||
if (res.getRecords() != null && res.getRecords().size() > 0) {
|
if (res.getRecords() != null && res.getRecords().size() > 0) {
|
||||||
for (AssessRectifyVo record : res.getRecords()) {
|
for (AssessRectifyVo record : res.getRecords()) {
|
||||||
record.setFiles(fileService.queryFileList(record.getId().toString(),getGroupId(),getScoreType()));
|
record.setFiles(fileService.queryFileList(record.getId().toString(), getGroupId(), getScoreType()));
|
||||||
record.setRectifyFiles(fileService.queryFileList(record.getId().toString(),getGroupId(),getRectifyType()));
|
record.setRectifyFiles(fileService.queryFileList(record.getId().toString(), getGroupId(), getRectifyType()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
|
|
@ -223,11 +239,11 @@ public class AssessTeamRatingService extends ServiceImpl<AssessTeamRatingMapper,
|
||||||
public String rectify(AssessTeamRating rating) {
|
public String rectify(AssessTeamRating rating) {
|
||||||
rating.setRectifyStatus(1);
|
rating.setRectifyStatus(1);
|
||||||
this.updateById(rating);
|
this.updateById(rating);
|
||||||
fileService.save(rating.getRectifyFiles(),rating.getId().toString(),getGroupId(),getRectifyType());
|
fileService.save(rating.getRectifyFiles(), rating.getId().toString(), getGroupId(), getRectifyType());
|
||||||
return "整改成功";
|
return "整改成功";
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<Integer,Long> rectifyStat(MonthRangeSo monthRangeSo) {
|
public Map<Integer, Long> rectifyStat(MonthRangeSo monthRangeSo) {
|
||||||
List<AssessTeamRating> list = this.baseMapper.rectifyStat(monthRangeSo);
|
List<AssessTeamRating> list = this.baseMapper.rectifyStat(monthRangeSo);
|
||||||
return list.stream().collect(Collectors.groupingBy(AssessTeamRating::getRectifyStatus, Collectors.counting()));
|
return list.stream().collect(Collectors.groupingBy(AssessTeamRating::getRectifyStatus, Collectors.counting()));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue