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

来源:互联网 发布:剑三苍云成女捏脸数据 编辑:程序博客网 时间:2024/05/16 10:06

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


完!




0 1
原创粉丝点击