From 58d9f460b2f8c34430285115e2557d18333c5cab Mon Sep 17 00:00:00 2001
From: Codex Assistant <codex@example.com>
Date: 星期三, 08 十月 2025 14:16:55 +0800
Subject: [PATCH] feat: 修复Player实体phone字段数据冗余问题并优化小程序报名逻辑

---
 backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java |   50 +++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 47 insertions(+), 3 deletions(-)

diff --git a/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java b/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java
index 7730408..dec8c64 100644
--- a/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java
+++ b/backend/src/main/java/com/rongyichuang/player/repository/ActivityPlayerRepository.java
@@ -8,6 +8,7 @@
 
 import java.util.List;
 import java.util.Optional;
+import java.time.LocalDateTime;
 
 /**
  * 娲诲姩閫夋墜Repository鎺ュ彛
@@ -26,9 +27,9 @@
     List<ActivityPlayer> findByPlayerId(Long playerId);
 
     /**
-     * 鏍规嵁娲诲姩ID鍜岄�夋墜ID鏌ユ壘鍙傝禌璁板綍
+     * 鏍规嵁娲诲姩ID鍜岄�夋墜ID鏌ユ壘鍙傝禌璁板綍鍒楄〃锛屾寜鍒涘缓鏃堕棿闄嶅簭鎺掑簭
      */
-    Optional<ActivityPlayer> findByActivityIdAndPlayerId(Long activityId, Long playerId);
+    List<ActivityPlayer> findByActivityIdAndPlayerIdOrderByCreateTimeDesc(Long activityId, Long playerId);
 
     /**
      * 鏍规嵁闃舵ID鏌ユ壘鍙傝禌閫夋墜
@@ -90,6 +91,32 @@
     List<ActivityPlayer> findTopRankedPlayers(@Param("activityId") Long activityId);
 
     /**
+     * 缁熻鏈�杩戞姤鍚嶈秼鍔匡紙浠呯涓�闃舵锛宻tate鍖呭惈寰呭鏍镐笌閫氳繃锛�
+     */
+    @Query(value = "SELECT DATE(ap.create_time) AS signup_date, COUNT(*) AS total " +
+            "FROM t_activity_player ap " +
+            "JOIN t_activity stage ON stage.id = ap.stage_id " +
+            "WHERE stage.sort_order = 1 AND stage.state = 1 " +
+            "  AND ap.state IN (0, 1) " +
+            "  AND ap.create_time >= :startDate " +
+            "GROUP BY DATE(ap.create_time) " +
+            "ORDER BY signup_date", nativeQuery = true)
+    List<Object[]> countFirstStageRegistrationsByDate(@Param("startDate") LocalDateTime startDate);
+
+    /**
+     * 缁熻鍚勫尯鍩熸姤鍚嶆暟閲忥紙浠呯涓�闃舵锛宻tate鍖呭惈寰呭鏍镐笌閫氳繃锛�
+     */
+    @Query(value = "SELECT ap.region_id, r.name, r.leaf_flag, COUNT(*) AS total " +
+            "FROM t_activity_player ap " +
+            "JOIN t_activity stage ON stage.id = ap.stage_id " +
+            "LEFT JOIN t_region r ON r.id = ap.region_id " +
+            "WHERE stage.sort_order = 1 AND stage.state = 1 " +
+            "  AND ap.state IN (0, 1) " +
+            "GROUP BY ap.region_id, r.name, r.leaf_flag " +
+            "ORDER BY total DESC", nativeQuery = true)
+    List<Object[]> countFirstStageRegistrationsByRegion();
+
+    /**
      * 缁熻鎸囧畾鐘舵�佺殑鍙傝禌閫夋墜鏁伴噺
      */
     long countByState(Integer state);
@@ -100,10 +127,22 @@
     Long countByStageIdAndState(Long stageId, Integer state);
 
     /**
+     * 鏍规嵁闃舵ID缁熻鍙傝禌閫夋墜鏁伴噺锛堝寘鎷湭瀹℃牳鍜屽鏍搁�氳繃鐨勶紝鎺掗櫎瀹℃牳椹冲洖鐨勶級
+     */
+    @Query("SELECT COUNT(ap) FROM ActivityPlayer ap WHERE ap.stageId = :stageId AND ap.state IN (0, 1)")
+    Long countByStageId(@Param("stageId") Long stageId);
+
+    /**
      * 鏍规嵁娲诲姩ID鍜岀姸鎬佺粺璁″弬璧涢�夋墜鏁伴噺
      */
     @Query("SELECT COUNT(ap) FROM ActivityPlayer ap WHERE ap.activityId = :activityId AND ap.state = :state")
     Long countByActivityIdAndState(@Param("activityId") Long activityId, @Param("state") Integer state);
+
+    /**
+     * 缁熻鍚屼竴娲诲姩+鍚屼竴閫夋墜鐨勬湁鏁堟姤鍚嶆暟閲忥紙state IN (0,1)锛�
+     */
+    @Query("SELECT COUNT(ap) FROM ActivityPlayer ap WHERE ap.activityId = :activityId AND ap.playerId = :playerId AND ap.state IN (0, 1)")
+    Long countActiveOrPendingByActivityAndPlayer(@Param("activityId") Long activityId, @Param("playerId") Long playerId);
 
     /**
      * 鏍规嵁闃舵ID鍜岀姸鎬佹煡鎵惧弬璧涢�夋墜锛堝寘鍚�夋墜淇℃伅锛�
@@ -118,4 +157,9 @@
      * 妫�鏌ラ�夋墜鏄惁宸插湪鎸囧畾闃舵鎶ュ悕
      */
     boolean existsByStageIdAndPlayerId(Long stageId, Long playerId);
-}
\ No newline at end of file
+
+    /**
+     * 鏍规嵁闃舵鍜岄�夋墜鏌ヨ鎶ュ悕璁板綍
+     */
+    Optional<ActivityPlayer> findByStageIdAndPlayerId(Long stageId, Long playerId);
+}

--
Gitblit v1.8.0