V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
gamexg
V2EX  ›  数据库

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

  •  
  •   gamexg · 2016-01-29 18:31:26 +08:00 · 818 次点击
    这是一个创建于 3227 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

    3 条回复    2016-01-30 10:04:42 +08:00
    bindiry
        1
    bindiry  
       2016-01-29 23:07:37 +08:00   ❤️ 1
    rails 里有一个特性,叫多态关联,就是在文件表里建一个字段,比如 file_type ,来用标识这条记录是用来关联 贴子表 还是 新闻表,关联查询的时候用这个字段做区别即可。
    mko0okmko0
        2
    mko0okmko0  
       2016-01-30 09:51:53 +08:00   ❤️ 1
    请问楼主想问的是类似 WIKI 这样的标签吗?
    每个文章内有许多标签,每个标签或多个标签指向某一个文章
    这样?
    gamexg
        3
    gamexg  
    OP
       2016-01-30 10:04:42 +08:00
    @bindiry 多谢,可惜一般都是用 sql 数据库。
    @mko0okmko0 不是标签类型。新闻允许上传文件,帖子也允许上传文件,现在需要记录文件到底属于哪篇文章或哪篇新闻。新闻、帖子逻辑不一致,会分别使用新闻表、帖子表来保存数据。文件逻辑是通用的,计划使用一个文件表,这样文件的所有者可能是新闻、也有可能是帖子两种表,标准的外键是不能用了...
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2909 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 03:34 · PVG 11:34 · LAX 19:34 · JFK 22:34
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.