mirror of
https://codeup.aliyun.com/67762337eccfc218f6110e0e/per-boe/java-servers.git
synced 2025-12-07 01:46:47 +08:00
Compare commits
3 Commits
757279e7ba
...
zcwy-0913-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ce1dae3ed2 | ||
|
|
4b1947bf06 | ||
|
|
39ba96f141 |
@@ -12,13 +12,16 @@ public class CaseScheduledTasks {
|
|||||||
@Resource
|
@Resource
|
||||||
private ICasesService casesService;
|
private ICasesService casesService;
|
||||||
|
|
||||||
@Scheduled(cron = "0 0 1 1 * ?") // 每月的第一天的1:00执行
|
/**
|
||||||
|
* 每月的第一天的1:00执行
|
||||||
|
*/
|
||||||
|
@Scheduled(cron = "0 0 1 1 * ?")
|
||||||
public void refreshViewsRankOfMajor() {
|
public void refreshViewsRankOfMajor() {
|
||||||
casesService.refreshViewsRankOfMajor();
|
casesService.refreshViewsRankOfMajor();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 季初执行,cron表达式设置为每个季度的第一个月的第一天的特定时间。每个季度的第一个月是1月、4月、7月和10月:
|
* 季初第一天两点执行,cron表达式设置为每个季度的第一个月的第一天的特定时间。每个季度的第一个月是1月、4月、7月和10月:
|
||||||
*/
|
*/
|
||||||
@Scheduled(cron = "0 0 2 1 1,4,7,10 ?")
|
@Scheduled(cron = "0 0 2 1 1,4,7,10 ?")
|
||||||
public void refreshLastQuarterStatistics() {
|
public void refreshLastQuarterStatistics() {
|
||||||
|
|||||||
@@ -132,25 +132,7 @@ public class CasesApi extends ApiBaseController {
|
|||||||
views = casesService.queryPageCasesV2(req);
|
views = casesService.queryPageCasesV2(req);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (views != null) {
|
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 {
|
|
||||||
views = new PageList();
|
views = new PageList();
|
||||||
views.setList(Collections.emptyList());
|
views.setList(Collections.emptyList());
|
||||||
views.setPageSize(req.getPageSize());
|
views.setPageSize(req.getPageSize());
|
||||||
|
|||||||
@@ -15,7 +15,9 @@ import java.util.stream.Collectors;
|
|||||||
@Repository
|
@Repository
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public class CasesRankDao extends BaseDao<CasesRank> {
|
public class CasesRankDao extends BaseDao<CasesRank> {
|
||||||
|
/**
|
||||||
|
* 获取类别榜记录,默认按上榜时间降序排列
|
||||||
|
*/
|
||||||
public List<CasesRank> findViewsRankRecordByCaseId(String caseId) {
|
public List<CasesRank> findViewsRankRecordByCaseId(String caseId) {
|
||||||
String sql =
|
String sql =
|
||||||
"SELECT bdmt.name,bcvr.rise_rank_time,bcvr.rank,bcvr.major_id \n" +
|
"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" +
|
"JOIN boe_dict_major_type bdmt \n" +
|
||||||
" ON bdmt.code = bcvr.major_id \n" +
|
" ON bdmt.code = bcvr.major_id \n" +
|
||||||
"WHERE bcvr.case_id = ?1 AND bcvr.deleted=0 AND bdmt.deleted=0\n" +
|
"WHERE bcvr.case_id = ?1 AND bcvr.deleted=0 AND bdmt.deleted=0\n" +
|
||||||
"ORDER BY bcvr.sys_update_time DESC \n" +
|
"ORDER BY bcvr.rise_rank_time DESC;";
|
||||||
"LIMIT 2;";
|
|
||||||
|
|
||||||
List<Object[]> list = this.sqlFindList(sql, caseId);
|
List<Object[]> list = this.sqlFindList(sql, caseId);
|
||||||
|
|
||||||
|
|||||||
@@ -416,14 +416,36 @@ public class CasesServiceImpl implements ICasesService {
|
|||||||
if (CollUtil.isEmpty(casesList)) {
|
if (CollUtil.isEmpty(casesList)) {
|
||||||
return casesList;
|
return casesList;
|
||||||
}
|
}
|
||||||
|
|
||||||
//1.推荐案例数据处理
|
//1.推荐案例数据处理
|
||||||
recommendCasesDataHandle(casesList, accountId);
|
recommendCasesDataHandle(casesList, accountId);
|
||||||
//2.标签处理,添加作者标签和新的案例标签
|
//2.标签处理,添加作者标签和新的案例标签
|
||||||
addAuthorTagAndCaseNewTag(casesList);
|
addAuthorTagAndCaseNewTag(casesList);
|
||||||
|
//3.案例类型处理
|
||||||
|
majorTypeHandle(casesList);
|
||||||
|
|
||||||
return 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) {
|
private void recommendCasesDataHandle(List<Cases> casesList, String accountId) {
|
||||||
if (StrUtil.isNotBlank(accountId)) {
|
if (StrUtil.isNotBlank(accountId)) {
|
||||||
List<String> caseIdList = casesList.stream().map(Cases::getId).collect(Collectors.toList());
|
List<String> caseIdList = casesList.stream().map(Cases::getId).collect(Collectors.toList());
|
||||||
@@ -483,7 +505,7 @@ public class CasesServiceImpl implements ICasesService {
|
|||||||
|
|
||||||
|
|
||||||
caseList.forEach(e -> {
|
caseList.forEach(e -> {
|
||||||
// 获取最新的两个浏览量上榜记录
|
// 获取浏览量上榜记录
|
||||||
List<CasesRank> viewsRankRecords = casesRankDao.findViewsRankRecordByCaseId(e.getId());
|
List<CasesRank> viewsRankRecords = casesRankDao.findViewsRankRecordByCaseId(e.getId());
|
||||||
if (CollUtil.isNotEmpty(viewsRankRecords)) {
|
if (CollUtil.isNotEmpty(viewsRankRecords)) {
|
||||||
// 拼接生成浏览量排行榜的标签
|
// 拼接生成浏览量排行榜的标签
|
||||||
@@ -1225,7 +1247,7 @@ public class CasesServiceImpl implements ICasesService {
|
|||||||
@Override
|
@Override
|
||||||
public void refreshLastQuarterStatistics() {
|
public void refreshLastQuarterStatistics() {
|
||||||
log.info("开始执行每季案例相关定时任务");
|
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);
|
log.info("每季案例相关定时任务执行完成,boe_cases更新数据量为条数为"+i);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1277,15 +1299,18 @@ public class CasesServiceImpl implements ICasesService {
|
|||||||
List<HashMap<String, Object>> popularityOfMajor = casesRankDao.findPopularityOfMajor(pageSize, startTime, endTime, majorId);
|
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());
|
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);
|
QueryBuilder query = QueryBuilder.from(Cases.class);
|
||||||
query.addFilter(FieldFilters.in("id",caseIdList));
|
query.addFilter(FieldFilters.in("id",caseIdList));
|
||||||
query.addFilter(FieldFilters.eq("deleted",false));
|
query.addFilter(FieldFilters.eq("deleted",false));
|
||||||
|
|
||||||
List<Cases> casesList = casesDao.findList(query.builder());
|
List<Cases> casesList = casesDao.findList(query.builder());
|
||||||
|
//处理案例数据-通用操作
|
||||||
casesList = caseListCommonHandle(casesList, accountId);
|
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>() {
|
Collections.sort(casesList, new Comparator<Cases>() {
|
||||||
@Override
|
@Override
|
||||||
public int compare(Cases c1, Cases c2) {
|
public int compare(Cases c1, Cases c2) {
|
||||||
@@ -1294,6 +1319,23 @@ public class CasesServiceImpl implements ICasesService {
|
|||||||
return Integer.compare(order1, order2);
|
return Integer.compare(order1, order2);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
//排序榜单案例标签顺序
|
||||||
|
casesList.forEach(cases -> {
|
||||||
|
List<CaseViewRankingItemVo> viewRankTags = cases.getViewRankTags();
|
||||||
|
Collections.sort(viewRankTags, new Comparator<CaseViewRankingItemVo>() {
|
||||||
|
@Override
|
||||||
|
public int compare(CaseViewRankingItemVo o1, CaseViewRankingItemVo o2) {
|
||||||
|
// 将 majorId 等于 传参majorId 的项优先排序
|
||||||
|
if (o1.getMajorId().equals(majorId) && !o2.getMajorId().equals(majorId)) {
|
||||||
|
return -1; // o1 应该排在 o2 前面
|
||||||
|
} else if (!o1.getMajorId().equals(majorId) && o2.getMajorId().equals(majorId)) {
|
||||||
|
return 1; // o2 应该排在 o1 前面
|
||||||
|
}
|
||||||
|
return 0; // 相同或两者都不是 传参majorId 时,保持原有顺序
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
return casesList;
|
return casesList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user