当前位置:首页 > PHP

php实现日榜周榜月榜

2026-01-29 07:53:11PHP

实现日榜、周榜、月榜的PHP方案

通过时间范围筛选数据并排序,结合数据库查询和缓存机制实现榜单功能。

数据库表设计

假设存储用户得分的表结构如下:

CREATE TABLE user_scores (
    id INT AUTO_INCREMENT PRIMARY KEY,
    user_id INT NOT NULL,
    score INT NOT NULL,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);

日榜实现

获取当日0点到当前时间的数据:

$todayStart = date('Y-m-d 00:00:00');
$todayEnd = date('Y-m-d H:i:s');

$dailyRanking = DB::table('user_scores')
    ->select('user_id', DB::raw('SUM(score) as total_score'))
    ->whereBetween('created_at', [$todayStart, $todayEnd])
    ->groupBy('user_id')
    ->orderByDesc('total_score')
    ->limit(10)
    ->get();

周榜实现

获取本周一0点到当前时间的数据:

$weekStart = date('Y-m-d 00:00:00', strtotime('last Monday'));
$weekEnd = date('Y-m-d H:i:s');

$weeklyRanking = DB::table('user_scores')
    ->select('user_id', DB::raw('SUM(score) as total_score'))
    ->whereBetween('created_at', [$weekStart, $weekEnd])
    ->groupBy('user_id')
    ->orderByDesc('total_score')
    ->limit(10)
    ->get();

月榜实现

获取本月1日0点到当前时间的数据:

$monthStart = date('Y-m-01 00:00:00');
$monthEnd = date('Y-m-d H:i:s');

$monthlyRanking = DB::table('user_scores')
    ->select('user_id', DB::raw('SUM(score) as total_score'))
    ->whereBetween('created_at', [$monthStart, $monthEnd])
    ->groupBy('user_id')
    ->orderByDesc('total_score')
    ->limit(10)
    ->get();

性能优化方案

使用Redis缓存榜单结果,避免频繁查询数据库:

$redis = new Redis();
$redis->connect('127.0.0.1', 6379);

// 日榜缓存键
$dailyKey = 'ranking:daily:' . date('Ymd');
if (!$redis->exists($dailyKey)) {
    // 从数据库获取并存入Redis
    $dailyData = /* 数据库查询逻辑 */;
    $redis->setex($dailyKey, 86400, json_encode($dailyData));
}
$dailyRanking = json_decode($redis->get($dailyKey));

定时任务更新

通过Crontab定时生成榜单:

0 0 * * * /usr/bin/php /path/to/update_daily_ranking.php
0 0 * * 1 /usr/bin/php /path/to/update_weekly_ranking.php
0 0 1 * * /usr/bin/php /path/to/update_monthly_ranking.php

数据结构优化

对于大规模数据,考虑使用专门的结构存储排名:

php实现日榜周榜月榜

// Redis有序集合实现实时排名
$redis->zAdd('daily_scores', $score, $user_id);
$dailyTop10 = $redis->zRevRange('daily_scores', 0, 9, true);

以上方案可根据实际业务需求调整时间范围定义和排序规则,缓存过期时间建议设置为对应榜单周期的自然结束时间。

分享给朋友:

相关文章

php实现打印功能

php实现打印功能

PHP 实现打印功能的方法 PHP 可以通过多种方式实现打印功能,具体取决于打印的目标(如打印机、PDF、网页等)和需求(如直接打印、生成打印预览等)。以下是几种常见的实现方式: 使用 JavaSc…

php实现文件下载

php实现文件下载

PHP实现文件下载的方法 通过PHP实现文件下载功能,可以采用多种方式,以下是几种常见的实现方法: 使用header()函数强制下载 设置HTTP头信息,强制浏览器下载文件而非直接打开: $fi…

php实现socket

php实现socket

PHP 实现 Socket 通信 PHP 可以通过 socket 扩展实现网络通信,支持 TCP/UDP 协议。以下是实现 Socket 通信的核心步骤和代码示例。 创建 TCP 服务器 // 创建…

php实现注册

php实现注册

注册功能实现步骤 数据库准备 创建用户表,包含字段如id、username、password、email等。示例SQL: CREATE TABLE users ( id INT AUTO_I…

php实现mvc

php实现mvc

PHP 实现 MVC 架构 MVC(Model-View-Controller)是一种常用的软件设计模式,将应用程序分为三个核心组件:模型(Model)、视图(View)和控制器(Controller…

php搜索功能的实现

php搜索功能的实现

实现PHP搜索功能的方法 数据库搜索 使用SQL的LIKE语句进行模糊匹配,适用于简单的搜索需求。 $searchTerm = $_GET['search']; $query = "SELECT *…