首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何避免需要两个外键引用同一个表

如何避免需要两个外键引用同一个表
EN

Stack Overflow用户
提问于 2012-02-14 00:44:52
回答 3查看 1.2K关注 0票数 0

我有一个Person表,需要记录该人过去和当前职业的数据。我有一张职业表,上面有职业名称和代码的列表。由于在Person表中,我不能将current_occupation作为外键引用职业,也不能将past_occuption作为外键引用职业,我该如何解决这个问题呢?即使我添加了一个辅助表来记录Person和职业之间的关系,我仍然会遇到同样的问题,即每个人都需要两条来自职业的数据。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-02-14 00:50:05

为什么不创建一个包含附加字段的PersonOccupation表,以便根据“最近”或应用日期对它们进行索引。然后从中派生出currentpast_occupation

那么您只需要一个外键就可以将PersonOccupationOccupation之间的OccupationId关联起来。

票数 0
EN

Stack Overflow用户

发布于 2012-02-14 00:55:21

在Person表中,您可以将current_occupation作为引用职业的外键,也可以将past_occuption作为引用职业的外键。在“关系”窗口中,添加“占用”表的第二个副本。然后创建一条从current_occupation到占领的一个副本的关系线,并创建另一个从past_occuption到另一个副本的关系线。

但是,这种方法会限制每个人只能使用一个past_occuption。如果你想为每个人记录多个以前的职业,Widor建议的设计会更好。

票数 1
EN

Stack Overflow用户

发布于 2012-02-14 05:28:55

代码语言:javascript
复制
SELECT Person.PersonId, Person.Name, 
CurrentOccupation.OccupationName AS CurrentOcc, 
PreviousOccupation.OccupationName AS PrevOcc
FROM (Person INNER JOIN Occupation AS CurrentOccupation ON Person.CurrentOccId = CurrentOccupation.OccupationId) 
INNER JOIN Occupation AS PreviousOccupation ON Person.PreviousOccId = PreviousOccupation.OccupationId;

这段代码在SQL中有两个occupation表,一次使用currentOcc的外键,一次使用previousOcc的外键,但是上面建议创建一个名为PersonOccupations的新表是一种更灵活、更健壮的解决方案,因为它允许人员担任任意数量的职务。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9264353

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档