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
完!
- web开发之收藏功能数据库设计
- web开发之附件数据库设计
- web开发之即时通讯数据库设计
- Web网站评论功能数据库设计和开发
- android开发之收藏网页功能
- [收藏]数据库主键设计之思考
- web开发之商城订单模块数据库设计
- Web 设计与开发终极资源大全 收藏
- JQuery插件(web设计、开发工具)收藏<持续更新>
- 数据库设计收藏
- 收藏表 数据库设计
- 收藏表 数据库设计
- 网站评论功能数据库设计和开发
- 网站评论功能数据库设计和开发
- 网站评论功能数据库设计和开发
- 网站评论功能数据库设计和开发
- 网址收藏 web开发
- Web开发相关收藏
- 杭电1002----高精度计算(加法)
- 随机抽样——蓄水池抽样算法(Reservoir Sampling)
- VBox Command
- uva 10602 Editor Nottoobad(字符串 + 排序)
- C语言二级指针
- web开发之收藏功能数据库设计
- You Are the One - HDU 4283 dp
- web开发之附件数据库设计
- Supermarket poj 1456 贪心+并查集优化
- 例题9-10 括号序列 UVa1626
- Android 判断app是否在前台还是在后台运行
- 康托展开和逆康托展开
- Java基础之Stack.peek()
- os运行一个程序时做了什么