web开发之收藏功能数据库设计

本文探讨了在web开发中,尤其是社交网络系统中,如何设计收藏功能的数据库。从最初的针对不同收藏类型(如微博、照片、活动、话题等)分别创建收藏表,到后来为应对项目扩大,提出了一种优化方案:统一收藏表结构,增加`collect_module`和`collect_table`字段,以记录收藏项目所属模块和具体表名,实现了多模块收藏的整合。

很多web项目中都会涉及到收藏功能的设计,用于用户保存自己喜欢的文字,图片,链接,多媒体等信息,这篇文章主要讲解的是如何设计多模块话网站的收藏功能的数据库。


假设做一个类似于新浪微博的社交网络系统,我们要实现一个收藏微博的功能,我们或许需要设计如下收藏表 pre_collect_feed

collect_id,collect_user,collect_feed,collect_time;

主键id,收藏用户,收藏的项目,收藏的时间;


现在因为用户需求,我们还要实现一个收藏照片的功能,我们或许需要设计如下收藏表pre_collect_photo

collect_id,collect_user,collect_photo,collect_time;

主键id,收藏用户,收藏的项目,收藏的时间;


现在因为用户需求,我们还要实现一个收藏活动的功能,我们或许需要设计如下收藏表pre_collect_event

collect_id,collect_user,collect_event,collect_time;

主键id,收藏用户,收藏的项目,收藏的时间;


现在因为用户需求,我们还要实现一个收藏话题的功能,我们或许需要设计如下收藏表pre_collect_topic

collect_id,collect_user,collect_topic,collect_time;

主键id,收藏用户,收藏的项目,收藏的时间;



随着项目的增大,我们需要设计收藏的条目越来越多,这时候就要找一种设计方法整合上面的各类收藏表。


解决方案:

首先,我们清楚的是,用户收藏的东西都对应了数据库表中的一条记录,而且这条记录在对应的表中是唯一的,所以,在收藏表中,只存储收藏条目在对应表中的主键是不行的,因为不同的表中的主键的值存放到一张收藏表中,这个值是可能一样的,比如用户发表的一条微博在微博表里面的主键是1,用户发布的一张图片在图片表里面的主键也是1,假设用户同时收藏了这条微博和这张照片,那么里面收藏的条目的id都是1的话,就没办法区分开来。如下所示:

collect_id,collect_user,collect_item,collect_time

1,1,1,141414142

2,1,1,141414146


所以,可以在上面的表结构上在增加个字段,用来记录收藏项目所在的表名称,甚至加上项目的模块名,如下所示

collect_id,collect_user,collect_module,collect_table,collect_row,collect_time

1,1,feed,pre_feed,1,141414142

2,1,photo,pre_photo,1,141414146


完!




评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值