为了账号安全,请及时绑定邮箱和手机立即绑定

可以对两个可能的表之一执行MySQL外键吗?

可以对两个可能的表之一执行MySQL外键吗?

呼如林 2019-06-29 17:24:15
可以对两个可能的表之一执行MySQL外键吗?这是我的问题-我有三张桌子:地区,国家,州。国家可以在区域之内,国家可以在区域内。区域是食物链的顶端。现在,我添加了一个具有两列的Popular_Regies表:Region_id和Popular_Place_id。是否有可能使Popular_Place_id成为任何一个国家的外键?或各州。我可能需要添加一个流行的_place_type列,以确定id是以任何方式描述国家还是州。
查看完整描述

3 回答

?
饮歌长啸

TA贡献1951条经验 获得超3个赞

这不是世界上最优雅的解决方案,但您可以使用混凝土表继承才能让这件事行得通。

从概念上讲,你提出了一类“可以成为流行领域的东西”的概念,你的三种类型的地方都继承了这些东西。您可以将它表示为一个表,例如,places中的一行具有一对一的关系。regionscountries,或states..(可以将区域、国家或州(如果有的话)共享的属性推入此Place表中。)你的popular_place_id然后是对Place表中的行的外键引用,该行将引导您到达某个区域、国家或州。

您提出的第二列描述关联类型的解决方案恰好是Rails处理多态关联的方式,但我一般不喜欢这样做

查看完整回答
反对 回复 2019-06-29
  • 3 回答
  • 0 关注
  • 571 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信