From b06162b2966eea4f092b3edf3032de843059af4b Mon Sep 17 00:00:00 2001
From: cloudroam <cloudroam>
Date: 星期四, 12 六月 2025 18:16:10 +0800
Subject: [PATCH] add: 评论开发

---
 src/main/java/com/mzl/flower/schedule/ScheduleService.java |   56 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 55 insertions(+), 1 deletions(-)

diff --git a/src/main/java/com/mzl/flower/schedule/ScheduleService.java b/src/main/java/com/mzl/flower/schedule/ScheduleService.java
index a9e05bd..7159b0c 100644
--- a/src/main/java/com/mzl/flower/schedule/ScheduleService.java
+++ b/src/main/java/com/mzl/flower/schedule/ScheduleService.java
@@ -1,5 +1,11 @@
 package com.mzl.flower.schedule;
 
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.mzl.flower.entity.film.FilmWorks;
+import com.mzl.flower.mapper.film.CommentPoMapper;
+import com.mzl.flower.mapper.film.FilmCollectsMapper;
+import com.mzl.flower.mapper.film.FilmLikesMapper;
+import com.mzl.flower.mapper.film.FilmWorksMapper;
 import com.mzl.flower.service.customer.CustomerService;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang3.time.DateFormatUtils;
@@ -8,12 +14,24 @@
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
+import javax.annotation.Resource;
+import java.time.LocalDate;
+import java.util.List;
+
 @Component
 @Slf4j
 public class ScheduleService {
 
-    @Autowired
+    @Resource
     private CustomerService customerService;
+    @Resource
+    private FilmWorksMapper filmWorksMapper;
+    @Resource
+    private FilmLikesMapper filmLikesMapper;
+    @Resource
+    private FilmCollectsMapper filmCollectsMapper;
+    @Resource
+    private CommentPoMapper commentPoMapper;
 
     @Scheduled(cron = "0 15 17 * * ?")
     @Profile("prod")
@@ -28,4 +46,40 @@
         customerService.checkVipExpireTime();
     }
 
+
+    //降低置顶权重。每天晚上11点执行一次
+    @Scheduled(cron = "0 0 23 * * ?")
+    public void downFilmWorksStickyWeight() {
+        // 每日减少10点权重,最低不低于0
+        filmWorksMapper.update(null, new LambdaUpdateWrapper<FilmWorks>().setSql("sticky_weight = GREATEST(sticky_weight - 10, 0)"));
+        log.info("每日置顶权重降低完成");
+    }
+
+    //提高置顶权重。每天早上6点执行一次(设计当天点赞+5,评论+10,收藏+10)
+    @Scheduled(cron = "0 0 6 * * ?")
+    public void upFilmWorksStickyWeight() {
+        // 获取昨天(当天)的互动数据
+        LocalDate yesterday = LocalDate.now().minusDays(1);
+
+        // 获取所有需要更新的作品
+        List<FilmWorks> worksList = filmWorksMapper.selectList(null);
+
+        worksList.forEach(work -> {
+            // 获取点赞数(需要实现统计方法)
+            int likes = filmLikesMapper.countByFilmIdAndDate(work.getId(), yesterday);
+            // 获取评论数(需要实现统计方法)
+            int comments = filmCollectsMapper.countByFilmIdAndDate(work.getId(), yesterday);
+            // 获取收藏数(需要实现统计方法)
+            int collects = commentPoMapper.countByFilmIdAndDate(work.getId(), yesterday);
+            // 计算权重增量
+            int increment = likes * 5 + comments * 10 + collects * 10;
+
+            if (increment > 0) {
+                filmWorksMapper.update(null, new LambdaUpdateWrapper<FilmWorks>().eq(FilmWorks::getId, work.getId()).setSql("sticky_weight = sticky_weight + " + increment));
+            }
+        });
+        log.info("每日互动权重加成完成");
+    }
+
+
 }

--
Gitblit v1.9.3