当前位置:首页 > PHP

php实现日榜周榜月榜

2026-04-03 14:08:43PHP

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

实现日榜、周榜和月榜的核心逻辑是通过时间筛选数据,并按指定规则排序。以下是具体实现方案:

数据库表设计

假设有一个记录用户得分的表scores,结构如下:

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

日榜实现

获取当天得分的排行榜:

$today = date('Y-m-d');
$sql = "SELECT user_id, SUM(score) as total_score 
        FROM scores 
        WHERE DATE(created_at) = :today 
        GROUP BY user_id 
        ORDER BY total_score DESC 
        LIMIT 10";
$stmt = $pdo->prepare($sql);
$stmt->execute([':today' => $today]);
$dailyRanking = $stmt->fetchAll(PDO::FETCH_ASSOC);

周榜实现

获取本周得分的排行榜:

$weekStart = date('Y-m-d', strtotime('this week Monday'));
$weekEnd = date('Y-m-d', strtotime('this week Sunday'));
$sql = "SELECT user_id, SUM(score) as total_score 
        FROM scores 
        WHERE DATE(created_at) BETWEEN :weekStart AND :weekEnd 
        GROUP BY user_id 
        ORDER BY total_score DESC 
        LIMIT 10";
$stmt = $pdo->prepare($sql);
$stmt->execute([
    ':weekStart' => $weekStart,
    ':weekEnd' => $weekEnd
]);
$weeklyRanking = $stmt->fetchAll(PDO::FETCH_ASSOC);

月榜实现

获取本月得分的排行榜:

$monthStart = date('Y-m-01');
$monthEnd = date('Y-m-t');
$sql = "SELECT user_id, SUM(score) as total_score 
        FROM scores 
        WHERE DATE(created_at) BETWEEN :monthStart AND :monthEnd 
        GROUP BY user_id 
        ORDER BY total_score DESC 
        LIMIT 10";
$stmt = $pdo->prepare($sql);
$stmt->execute([
    ':monthStart' => $monthStart,
    ':monthEnd' => $monthEnd
]);
$monthlyRanking = $stmt->fetchAll(PDO::FETCH_ASSOC);

性能优化方案

对于大型应用,考虑以下优化措施:

  • created_at字段创建索引
  • 使用缓存(Redis)存储排行榜结果
  • 定时任务预计算排行榜数据

Redis缓存实现示例

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

// 获取日榜缓存
if (!$dailyRanking = $redis->get('daily_ranking')) {
    // 缓存不存在时从数据库获取
    $dailyRanking = getDailyRankingFromDB();
    $redis->setex('daily_ranking', 3600, json_encode($dailyRanking));
} else {
    $dailyRanking = json_decode($dailyRanking, true);
}

定时任务更新

使用Cron定时更新排行榜:

php实现日榜周榜月榜

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

分享给朋友:

相关文章

php实现登录

php实现登录

PHP 登录功能实现 数据库连接与用户表创建 创建一个数据库连接文件 db.php,用于管理数据库连接。MySQL 示例代码如下: <?php $host = 'localhost'; $db…

php 函数实现

php 函数实现

PHP 函数实现基础 PHP 函数的定义使用 function 关键字,后跟函数名和参数列表。函数名不区分大小写,但建议保持一致。 function functionName($param1, $p…

php 实现类

php 实现类

PHP 类的基本实现 在 PHP 中,类通过 class 关键字定义,后跟类名和一对花括号。类名通常遵循大驼峰命名法(如 ClassName)。以下是基本语法: class ClassName {…

php实现的进度条

php实现的进度条

PHP 实现的进度条方法 在 PHP 中实现进度条通常可以通过命令行脚本(CLI)或 Web 页面两种方式完成。以下是几种常见的实现方法: 命令行进度条 使用 PHP CLI 实现进度条,可以通过不…

php 实现md5

php 实现md5

使用 PHP 内置函数实现 MD5 PHP 提供了 md5() 函数,可以直接计算字符串的 MD5 哈希值。该函数接受一个字符串参数,返回 32 字符的十六进制哈希值。 $string = "H…

php搜索功能的实现

php搜索功能的实现

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