所以我有一个SQL关系问题。假设我有一个数据库,我想在其中保存有关个人的信息记录。现在我已经设置了一个表格来获取这些信息。好的,到目前为止一切都很好。
通常可以在表中发现重复信息并将其删除。如果特定字段与另一行中的另一个字段具有相同的值,则记录被认为是重复的。示例:重复的电子邮件。
现在我想在数据库中创建另一个表来跟踪发现和删除的每个重复项。我的第一个想法是创建一个外键关系。所以我创建了一个表并将其连接dupes
到我的persons
表。该关系是具有删除约束的简单外键与主键关系。
现在虽然起初这可能有效,但问题出现了,该dupes
表正在接收已删除的记录,即使它们没有被删除,因为它们是骗子。这是一个问题,因为即使我决定从persons
表中删除一个人只是因为我不喜欢他们,他们还是会存储在dupes
表中。
disposition field
然后我想,为什么不在表中创建一个persons
并将其作为唯一键或主键连接到我dupes
表的索引外键。那么问题是一个唯一的键必须有一个唯一的值,所以多重处置dupe
或I don't like you
将不起作用。另一种选择是设置disposition field
主键。但这也有同样的问题。
这个问题的正确关系是什么?