0

0

PHP如何实现视频收藏功能_PHP实现视频收藏功能逻辑【收藏】

看不見的法師

看不見的法師

发布时间:2026-01-19 20:15:30

|

751人浏览过

|

来源于php中文网

原创

应设计独立中间表video_favorites,含user_id、video_id联合唯一索引及双向普通索引,并启用级联删除;收藏/取消用INSERT IGNORE+事务判断行数实现原子操作;用户收藏状态通过一次性查询+array_flip后isset()高效判断;收藏数须Redis缓存并双写更新。

php如何实现视频收藏功能_php实现视频收藏功能逻辑【收藏】

用户收藏关系表怎么设计才合理

视频收藏本质是多对多关系:一个用户可以收藏多个视频,一个视频也能被多个用户收藏。直接在 videos 表加 collected_user_ids 字段(如 JSON 数组)看似简单,但会破坏范式、无法索引、难以统计和查询。

必须建独立中间表:

CREATE TABLE video_favorites (
    id BIGINT UNSIGNED PRIMARY KEY AUTO_INCREMENT,
    user_id INT UNSIGNED NOT NULL,
    video_id INT UNSIGNED NOT NULL,
    created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
    UNIQUE KEY uk_user_video (user_id, video_id),
    KEY idx_video_user (video_id, user_id),
    FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE,
    FOREIGN KEY (video_id) REFERENCES videos(id) ON DELETE CASCADE
);
  • UNIQUE KEY uk_user_video 防止重复收藏,也是判断是否已收藏的最快依据
  • KEY idx_video_user 支持按视频查所有收藏者(比如“谁收藏了这个视频”)
  • ON DELETE CASCADE 保证视频或用户删除时自动清理收藏记录

收藏/取消收藏接口如何避免并发重复提交

用户快速双击“收藏”按钮,可能触发两次请求,导致插入重复记录(虽然唯一索引会报错),但错误处理不优雅,还可能影响前端状态同步。

推荐用原子操作 + 前端防抖结合:

立即学习PHP免费学习笔记(深入)”;

  • 后端INSERT ... ON DUPLICATE KEY UPDATEREPLACE INTO,但更稳妥的是先 SELECTINSERT/DELETE,配合事务
  • 实际推荐用 MySQL 的 INSERT IGNORE + 返回影响行数判断
  • PHP 示例中不要用 if (already_exists) { delete } else { insert } 这种两步查询,有竞态风险
$pdo = new PDO(...);
$pdo->beginTransaction();
$stmt = $pdo->prepare("INSERT IGNORE INTO video_favorites (user_id, video_id) VALUES (?, ?)");
$stmt->execute([$user_id, $video_id]);
if ($stmt->rowCount() === 1) {
    // 新增成功 → 是收藏操作
    $result = ['action' => 'collected', 'count' => getFavoriteCount($video_id)];
} elseif ($stmt->rowCount() === 0) {
    // 无新增 → 尝试删除
    $del = $pdo->prepare("DELETE FROM video_favorites WHERE user_id = ? AND video_id = ?");
    $del->execute([$user_id, $video_id]);
    if ($del->rowCount() === 1) {
        $result = ['action' => 'canceled', 'count' => getFavoriteCount($video_id)];
    } else {
        throw new Exception('操作失败:未收藏也无法取消');
    }
}
$pdo->commit();

如何高效查询“用户是否收藏了某视频”

首页列表、详情页都需要实时显示“已收藏”状态,不能每个视频都查一次数据库。

音剪
音剪

喜马拉雅旗下的一站式AI音频创作平台,强大的在线剪辑能力,帮你轻松创作优秀的音频作品

下载

最常用且低开销的方式是:一次性查出该用户所有收藏的 video_id,存为 PHP 关联数组键(array_flip()),再用 isset() 判断:

$favoriteVideoIds = array_flip(
    $pdo->query("SELECT video_id FROM video_favorites WHERE user_id = $user_id")->fetchAll(PDO::FETCH_COLUMN)
);
// 渲染视频列表时
foreach ($videos as $v) {
    $isFavorited = isset($favoriteVideoIds[$v['id']]);
    echo '';
}
  • 比循环中对每个视频执行 SELECT COUNT(*) 快一个数量级
  • 如果用户收藏量极大(>5k),可改用 Redis 的 SET 存储 user:123:favorites,用 SISMEMBER 查询
  • 注意:不能用 IN 子查询把收藏 ID 拼进视频主查询——ID 太多会超 SQL 长度限制,也难优化

收藏数缓存为什么不能只靠数据库 COUNT(*)

视频详情页显示“已有 24832 人收藏”,每次访问都执行 SELECT COUNT(*) FROM video_favorites WHERE video_id = ?,在高并发下会成为性能瓶颈,尤其当收藏表超百万行时。

必须引入缓存层,但要注意一致性:

  • 收藏/取消时,除了操作 video_favorites 表,**必须同步更新缓存**(如 Redis 的 video:123:favorite_count
  • 缓存设带过期时间(如 3600 秒),防止极端情况下缓存与 DB 不一致太久
  • 避免用“读时回源 + 加锁更新”这种复杂方案;简单场景下,写操作双写(DB + Cache)足够可靠
  • Redis 示例:INCRBY video:123:favorite_count 1 / DECRBY video:123:favorite_count 1

缓存失效不是最难的,难的是写操作漏掉缓存更新——这是线上最常导致“收藏数不准”的原因。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2687

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1662

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1523

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

953

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1420

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1488

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

23

2026.01.19

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.8万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 801人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号