mirror of
https://codeup.aliyun.com/67762337eccfc218f6110e0e/per-boe/java-servers.git
synced 2025-12-06 09:26:48 +08:00
Merge remote-tracking branch 'yx/zcwy0913-yang-case-prod'
This commit is contained in:
@@ -12,13 +12,16 @@ public class CaseScheduledTasks {
|
||||
@Resource
|
||||
private ICasesService casesService;
|
||||
|
||||
@Scheduled(cron = "0 0 1 1 * ?") // 每月的第一天的1:00执行
|
||||
/**
|
||||
* 每月的第一天的1:00执行
|
||||
*/
|
||||
@Scheduled(cron = "0 0 1 1 * ?")
|
||||
public void refreshViewsRankOfMajor() {
|
||||
casesService.refreshViewsRankOfMajor();
|
||||
}
|
||||
|
||||
/**
|
||||
* 季初执行,cron表达式设置为每个季度的第一个月的第一天的特定时间。每个季度的第一个月是1月、4月、7月和10月:
|
||||
* 季初第一天两点执行,cron表达式设置为每个季度的第一个月的第一天的特定时间。每个季度的第一个月是1月、4月、7月和10月:
|
||||
*/
|
||||
@Scheduled(cron = "0 0 2 1 1,4,7,10 ?")
|
||||
public void refreshLastQuarterStatistics() {
|
||||
|
||||
@@ -132,25 +132,7 @@ public class CasesApi extends ApiBaseController {
|
||||
views = casesService.queryPageCasesV2(req);
|
||||
}
|
||||
|
||||
if (views != null) {
|
||||
List<Cases> cases = views.getList();
|
||||
if (CollUtil.isNotEmpty(cases)) {
|
||||
for (Cases c : cases) {
|
||||
StringBuffer stringBuffer = new StringBuffer();
|
||||
List<CasesMajorType> caseId = casesMajorTypeDao.findList(FieldFilters.eq("caseId", c.getId()));
|
||||
if (caseId != null && !caseId.isEmpty()) {
|
||||
for (CasesMajorType cm : caseId) {
|
||||
stringBuffer.append(cm.getMajorId());
|
||||
stringBuffer.append(",");
|
||||
}
|
||||
}
|
||||
if (stringBuffer.length() > 0) {
|
||||
stringBuffer.deleteCharAt(stringBuffer.length() - 1);
|
||||
c.setMajorType(stringBuffer.toString());
|
||||
}
|
||||
}
|
||||
}
|
||||
} else {
|
||||
if (views == null) {
|
||||
views = new PageList();
|
||||
views.setList(Collections.emptyList());
|
||||
views.setPageSize(req.getPageSize());
|
||||
|
||||
@@ -15,7 +15,9 @@ import java.util.stream.Collectors;
|
||||
@Repository
|
||||
@Slf4j
|
||||
public class CasesRankDao extends BaseDao<CasesRank> {
|
||||
|
||||
/**
|
||||
* 获取类别榜记录,默认按上榜时间降序排列
|
||||
*/
|
||||
public List<CasesRank> findViewsRankRecordByCaseId(String caseId) {
|
||||
String sql =
|
||||
"SELECT bdmt.name,bcvr.rise_rank_time,bcvr.rank,bcvr.major_id \n" +
|
||||
@@ -24,8 +26,7 @@ public class CasesRankDao extends BaseDao<CasesRank> {
|
||||
"JOIN boe_dict_major_type bdmt \n" +
|
||||
" ON bdmt.code = bcvr.major_id \n" +
|
||||
"WHERE bcvr.case_id = ?1 AND bcvr.deleted=0 AND bdmt.deleted=0\n" +
|
||||
"ORDER BY bcvr.sys_update_time DESC \n" +
|
||||
"LIMIT 2;";
|
||||
"ORDER BY bcvr.rise_rank_time DESC;";
|
||||
|
||||
List<Object[]> list = this.sqlFindList(sql, caseId);
|
||||
|
||||
|
||||
@@ -416,14 +416,36 @@ public class CasesServiceImpl implements ICasesService {
|
||||
if (CollUtil.isEmpty(casesList)) {
|
||||
return casesList;
|
||||
}
|
||||
|
||||
//1.推荐案例数据处理
|
||||
recommendCasesDataHandle(casesList, accountId);
|
||||
//2.标签处理,添加作者标签和新的案例标签
|
||||
addAuthorTagAndCaseNewTag(casesList);
|
||||
//3.案例类型处理
|
||||
majorTypeHandle(casesList);
|
||||
|
||||
return casesList;
|
||||
}
|
||||
|
||||
private void majorTypeHandle(List<Cases> casesList) {
|
||||
if (CollUtil.isNotEmpty(casesList)) {
|
||||
for (Cases c : casesList) {
|
||||
StringBuffer stringBuffer = new StringBuffer();
|
||||
List<CasesMajorType> caseId = casesMajorTypeDao.findList(FieldFilters.eq("caseId", c.getId()));
|
||||
if (caseId != null && !caseId.isEmpty()) {
|
||||
for (CasesMajorType cm : caseId) {
|
||||
stringBuffer.append(cm.getMajorId());
|
||||
stringBuffer.append(",");
|
||||
}
|
||||
}
|
||||
if (stringBuffer.length() > 0) {
|
||||
stringBuffer.deleteCharAt(stringBuffer.length() - 1);
|
||||
c.setMajorType(stringBuffer.toString());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void recommendCasesDataHandle(List<Cases> casesList, String accountId) {
|
||||
if (StrUtil.isNotBlank(accountId)) {
|
||||
List<String> caseIdList = casesList.stream().map(Cases::getId).collect(Collectors.toList());
|
||||
@@ -483,7 +505,7 @@ public class CasesServiceImpl implements ICasesService {
|
||||
|
||||
|
||||
caseList.forEach(e -> {
|
||||
// 获取最新的两个浏览量上榜记录
|
||||
// 获取浏览量上榜记录
|
||||
List<CasesRank> viewsRankRecords = casesRankDao.findViewsRankRecordByCaseId(e.getId());
|
||||
if (CollUtil.isNotEmpty(viewsRankRecords)) {
|
||||
// 拼接生成浏览量排行榜的标签
|
||||
@@ -1231,7 +1253,7 @@ public class CasesServiceImpl implements ICasesService {
|
||||
@Override
|
||||
public void refreshLastQuarterStatistics() {
|
||||
log.info("开始执行每季案例相关定时任务");
|
||||
int i = casesDao.sqlUpdate("update boe_cases set last_quarter_views=views,last_quarter_praise=praise where deleted=0");
|
||||
int i = casesDao.sqlUpdate("update boe_cases set last_quarter_views=views,last_quarter_praises=praises where deleted=0");
|
||||
log.info("每季案例相关定时任务执行完成,boe_cases更新数据量为条数为"+i);
|
||||
}
|
||||
|
||||
@@ -1283,15 +1305,18 @@ public class CasesServiceImpl implements ICasesService {
|
||||
List<HashMap<String, Object>> popularityOfMajor = casesRankDao.findPopularityOfMajor(pageSize, startTime, endTime, majorId);
|
||||
List<String> caseIdList = popularityOfMajor.stream().map(map -> map.get("caseId").toString()).collect(Collectors.toList());
|
||||
|
||||
Map<Object, Integer> collect = popularityOfMajor.stream().collect(Collectors.toMap(map -> map.get("caseId").toString(), map -> Integer.valueOf(map.get("rank").toString())));
|
||||
|
||||
QueryBuilder query = QueryBuilder.from(Cases.class);
|
||||
query.addFilter(FieldFilters.in("id",caseIdList));
|
||||
query.addFilter(FieldFilters.eq("deleted",false));
|
||||
|
||||
List<Cases> casesList = casesDao.findList(query.builder());
|
||||
//处理案例数据-通用操作
|
||||
casesList = caseListCommonHandle(casesList, accountId);
|
||||
//获取案例与排名的映射关系
|
||||
Map<Object, Integer> collect = popularityOfMajor.stream().collect(Collectors.toMap(map -> map.get("caseId").toString(), map -> Integer.valueOf(map.get("rank").toString())));
|
||||
|
||||
//排序榜单案例顺序
|
||||
Collections.sort(casesList, new Comparator<Cases>() {
|
||||
@Override
|
||||
public int compare(Cases c1, Cases c2) {
|
||||
@@ -1300,6 +1325,26 @@ public class CasesServiceImpl implements ICasesService {
|
||||
return Integer.compare(order1, order2);
|
||||
}
|
||||
});
|
||||
|
||||
casesList.forEach(cases -> {
|
||||
List<CaseViewRankingItemVo> viewRankTags = cases.getViewRankTags();
|
||||
|
||||
// 使用 Stream API 进行排序,保持其余元素的原始顺序
|
||||
List<CaseViewRankingItemVo> sortedList = viewRankTags.stream()
|
||||
.sorted((o1, o2) -> {
|
||||
// majorId 相等时放前面
|
||||
boolean o1Matches = o1.getMajorId().equals(majorId);
|
||||
boolean o2Matches = o2.getMajorId().equals(majorId);
|
||||
|
||||
if (o1Matches && !o2Matches) return -1; // o1是majorId, o2不是,o1排前
|
||||
if (!o1Matches && o2Matches) return 1; // o2是majorId, o1不是,o2排前
|
||||
return 0; // 如果两者都是或都不是majorId, 保持原有顺序
|
||||
})
|
||||
.collect(Collectors.toList());
|
||||
|
||||
// 更新原列表
|
||||
cases.setViewRankTags(sortedList);
|
||||
});
|
||||
return casesList;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user