我应该创建一个可以为空的外键还是创建一个新表?

Big*_*low 6 database database-design foreign-keys relational-database database-schema

我有一个关于如何设计数据库的小问题。我有一个动物收容所的桌狗,我有一个桌主人。所有现在和曾经在收容所的狗都被安置在餐桌狗中。现在我想在桌狗和桌主人之间建立联系。

问题是,在这个例子中,并不是所有的狗都有主人,并且由于一个主人可以有不止一只狗,所以应该在狗表中放置一个可能的外键(一只狗至少不能有多个主人)不在庇护所的管理范围内)。但如果我这样做,一些狗(收容所里的狗)的外键将为 null。阅读其他一些主题告诉我这是允许的。(或者我可能读错了一些主题)

然而,另一种可能性是在两个表之间放置一个表 - 例如“dogswithowners” - 如果狗有主人,则将两个表的主键都放在那里。

现在我的问题是(正如您可能已经猜到的)这两种方法中最好的方法是什么?为什么?

Zoh*_*led 0

用于外键关系的可为空列是完全有效的,并且用于与您的场景完全相同的场景。

添加另一个表来连接owners表和dogs表将创建多对多关系,除非在其中一个列(在您的情况下是dogs)上创建唯一约束。

由于您描述了一对多关系,我会选择第一个选项,即具有可为空的外键,因为我发现它更具可读性。