一个数据库设计问题:帖子、新闻等等内容都可能有关联的文件,那么文件表、帖子表、新闻表的外键怎么设计比较好?

2016-01-29 18:31:26 +08:00
 gamexg

由于帖子、新闻的字段不一致,并且处理逻辑也不一致,需要分别使用不同的表。
帖子、新闻关联的文件表字段、逻辑是一致的,计划使用同一个表。

那么文件和帖子、新闻的关联就有些麻烦,我一直是将文件所有者字段设置为字符串格式,通过 "所有者类型.所有者 id" 来解决这个麻烦的。

另一个选择是设置一个单独的 id 表,用来生成帖子、新闻的全库唯一 id 。字段为: id 、类型(帖子、新闻)。帖子、新闻再设置一个单独的表存放实际内容,然后通过外键关联到 id 表。

大家有什么更好的办法吗?

785 次点击
所在节点    数据库
3 条回复
bindiry
2016-01-29 23:07:37 +08:00
rails 里有一个特性,叫多态关联,就是在文件表里建一个字段,比如 file_type ,来用标识这条记录是用来关联 贴子表 还是 新闻表,关联查询的时候用这个字段做区别即可。
mko0okmko0
2016-01-30 09:51:53 +08:00
请问楼主想问的是类似 WIKI 这样的标签吗?
每个文章内有许多标签,每个标签或多个标签指向某一个文章
这样?
gamexg
2016-01-30 10:04:42 +08:00
@bindiry 多谢,可惜一般都是用 sql 数据库。
@mko0okmko0 不是标签类型。新闻允许上传文件,帖子也允许上传文件,现在需要记录文件到底属于哪篇文章或哪篇新闻。新闻、帖子逻辑不一致,会分别使用新闻表、帖子表来保存数据。文件逻辑是通用的,计划使用一个文件表,这样文件的所有者可能是新闻、也有可能是帖子两种表,标准的外键是不能用了...

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/254298

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX