如何绕过需要两个引用同一个表的外键

时间:2012-02-13 16:44:52

标签: database-design ms-access foreign-keys relational-database

我有一个人员表,需要记录该人过去和当前职业的数据。我有一个职业表,其中包含职业名称和代码列表。因为在Person表中我不能将current_occupation作为引用Occupation的外键以及past_occuption作为引用Occupation的外键,我该如何解决这个问题呢?即使我添加一个辅助表来记录Person和Occupation之间的关系,我仍然遇到需要两个来自Occupation的数据的问题。

3 个答案:

答案 0 :(得分:1)

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

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

答案 1 :(得分:1)

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中有两次占用表,一次使用currentOcc的外键,一次使用externalOcc的外键,但上面建议创建一个名为PersonOccupations的新表是一个更灵活,更强大的解决方案,因为它允许任何这个人的职业数量。

答案 2 :(得分:0)

为什么不在PersonOccupation表中添加其他字段,以便按“最近”或仅仅应用它们的日期对其进行索引。然后从中获取currentpast_occupation

然后,您只需要一个与OccupationIdPersonOccupation之间Occupation相关的外键。