这听起来可能令人困惑或简单,但是..。
如果我使用表A表B中的外键,表A中有一个单独的主键。I是否需要将表A的主键作为外键包含在表B中?
谢谢!
========================================================================
编辑:
好吧,让我试着澄清一下我的问题。

在上面的例子中,I应该在表2中使用Taco_ID作为FK吗?还是完全没有必要?
发布于 2016-10-27 20:44:21
在大多数数据库中,外键引用必须是对主键或唯一键的引用(并且允许使用NULL)。MySQL建议这样做,但不需要它。
但是,系统不强制要求引用的列是唯一的或声明为NULL。对非唯一键或包含空值的键的外键引用的处理对于诸如UPDATE或DELETE级联之类的操作没有很好的定义。建议您使用只引用唯一(包括主键)和非空键的外键。
是否需要引用外键关系的主键?首先,您甚至不需要声明外键关系。我认为它们很重要,因为它们允许数据库维护引用的完整性。但是,它们并不是必需的。基于外键的存在,查询中也没有任何语义差异(例如,NATURAL JOIN不使用它们)。优化可以使用声明的关系。
其次,如果要声明外键,我建议使用引用表的主键。这毕竟是拥有主键的主要原因之一。
https://stackoverflow.com/questions/40293737
复制相似问题