fix(dashboard): 优化活跃用户统计逻辑

- 修改活跃用户数统计方式,解决groupBy无法正确统计不重复用户数的问题
- 改为先查询符合条件的登录记录,再使用Stream API统计不重复用户名
- 提高统计准确性,确保活跃用户数据的正确性
- 添加详细的中文注释说明统计逻辑
This commit is contained in:
Leo 2025-09-24 22:19:59 +08:00
parent d9fb89adad
commit 28941ede41

View File

@ -152,17 +152,20 @@ public class DashboardServiceImpl implements DashboardService {
);
// 活跃用户数最近30天有登录记录的用户
// 使用原生SQL统计不重复的登录用户数
LambdaQueryWrapper<SysLoginLog> activeWrapper =
new LambdaQueryWrapper<>();
activeWrapper
.apply("login_time >= DATE_SUB(NOW(), INTERVAL 30 DAY)")
.eq(SysLoginLog::getLoginStatus, "0")
.select(SysLoginLog::getLoginName)
.groupBy(SysLoginLog::getLoginName);
Long activeUsers = sysLoginLogMapper.selectCount(activeWrapper);
userStats.setActiveUsers(
activeUsers != null ? activeUsers.intValue() : 0
);
.eq(SysLoginLog::getLoginStatus, "0");
// 获取符合条件的登录记录然后统计不重复的用户名
List<SysLoginLog> loginLogs = sysLoginLogMapper.selectList(activeWrapper);
long activeUsers = loginLogs.stream()
.map(SysLoginLog::getLoginName)
.distinct()
.count();
userStats.setActiveUsers((int) activeUsers);
// 当前在线用户数通过Sa-Token获取
List<String> onlineTokens = StpUtil.searchTokenValue(