0

0

如何在mysql中实现收藏功能_mysql收藏功能表设计

P粉602998670

P粉602998670

发布时间:2025-12-17 10:05:13

|

322人浏览过

|

来源于php中文网

原创

MySQL收藏功能需设计用户-资源多对多表,核心字段含user_id、target_id(或article_id)、created_at,加联合唯一索引(user_id,target_type,target_id)防重复,并建对应查询索引。

如何在mysql中实现收藏功能_mysql收藏功能表设计

在 MySQL 中实现收藏功能,核心是设计一张“用户-资源”多对多关系表,记录谁收藏了什么,并支持快速查询、去重和取消收藏。

收藏表基础结构设计

收藏行为本质是用户(user)和被收藏对象(如文章、商品、视频等)之间的关联。假设被收藏的是文章(article),推荐表结构如下:

  • id:主键,自增 bigint,便于分页和索引优化
  • user_id:收藏用户的 ID(对应 users 表主键),加索引
  • target_type:可选,用于泛化收藏类型(如 'article'、'product'、'video'),方便统一收藏表管理多个资源类型
  • target_id:被收藏资源的主键 ID(如 article.id),加索引
  • created_at:收藏时间,datetime 或 timestamp,默认 CURRENT_TIMESTAMP

关键约束:联合唯一索引 (user_id, target_type, target_id),防止同一用户重复收藏同一内容。

单类型收藏(简单场景)

如果只收藏一种资源(比如仅文章),可简化设计,去掉 target_type

CREATE TABLE user_favorites (
  id BIGINT PRIMARY KEY AUTO_INCREMENT,
  user_id BIGINT NOT NULL,
  article_id BIGINT NOT NULL,
  created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
  UNIQUE KEY uk_user_article (user_id, article_id),
  KEY idx_user (user_id),
  KEY idx_article (article_id)
);

这样插入时用 INSERT IGNOREON DUPLICATE KEY UPDATE 可安全处理重复收藏。

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

下载

收藏状态查询与业务逻辑

常见需求包括:查某用户所有收藏、查某文章被多少人收藏、判断某用户是否已收藏某文章。

  • 查用户所有收藏文章(带文章信息):
    SELECT a.* FROM user_favorites f JOIN articles a ON f.article_id = a.id WHERE f.user_id = ?
  • 查文章收藏数:
    SELECT COUNT(*) FROM user_favorites WHERE article_id = ?
  • 判断是否已收藏(推荐用 EXISTS 提升效率):
    SELECT EXISTS(SELECT 1 FROM user_favorites WHERE user_id = ? AND article_id = ?)

扩展性与注意事项

若后续要支持多种资源类型,target_type + target_id 方案更灵活,但需注意:

  • 避免在 SQL 中大量使用 CASE WHEN 关联不同表,可考虑应用层分发查询
  • 收藏数高并发更新时,不建议用 UPDATE ... SET count = count + 1,应以“记录存在即算一次”为准,统计走聚合查询或异步更新计数缓存
  • 长期运行后收藏表可能很大,按 user_id 或时间分区/归档可提升维护性

不复杂但容易忽略:上线前务必给常用查询字段建好索引,尤其是 (user_id, target_type, target_id) 这个联合唯一键,它同时支撑去重、查询、删除三个核心操作。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

685

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

323

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

6

2026.01.23

热门下载

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

相关下载

更多

精品课程

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

共48课时 | 1.9万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 805人学习

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

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