很多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
完!

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





