2

我一直在使用与 SQL (MySQL) 和 Rails 的表关联没有问题,而且我从来不需要指定外键约束。

我只是在 belongs_to 表中添加了一个 table_id 列,一切正常。

那么我错过了什么?在 MySQL 或其他 RDBMS 中使用外键子句有什么意义?

谢谢。

4

5 回答 5

2

外键是两个表之间的引用约束

存在外键约束的原因是为了保证引用的行存在。

标识一个(引用或子)表中的一列或一组列,该表引用另一个(引用或父)表中的一列或一组列。

  • 您可以获得很好的“删除级联”行为,自动清理表

这里列出了很多使用外键的原因:为什么要使用外键

于 2013-01-01T05:46:57.470 回答
1

Rails(更具体地说是ActiveRecord )自动为您猜测外键。

...默认情况下,这被猜测为带有“_id”后缀的关联名称。

外键强制参照完整性

外键:表中的一列或一组列,其值需要与另一个表的一行的至少一个 PrimaryKey 值匹配。

也可以看看:

于 2013-01-01T05:47:23.050 回答
1

外键或任何引用约束的基本思想是数据库不应允许您存储明显无效的数据。它是数据一致性的核心组成部分,是ACID 规则之一。

如果您的数据模型表明您可以将多个电话号码与一个帐户关联,您可以将电话表定义为需要一个有效的帐号。因此,无法存储孤立的电话记录,因为您无法在没有有效帐号的情况下在电话表中插入一行,并且您无法在不先删除电话号码的情况下删除帐户。如果该字段是生日,您可能会强制要求日期早于明天的日期。如果字段是高度,您可以强制距离在 30 到 4000 厘米之间。这意味着任何应用程序都不可能在数据库中存储无效数据。

“好吧,为什么我不能把所有这些都写到我的应用程序中呢?” 你问。对于单应用程序数据库,您可以。但是,任何拥有存储用于业务运营的数据的重要数据库的企业都希望直接访问数据。他们希望能够从财务或 HR 导入数据,或将地址导出到销售,或通过从 Active Directory 导入它们来创建应用程序用户帐户等。对于非平凡的应用程序,用户的数据是最重要的,并且就是他们想要访问的内容。在某些时候,他们会希望在您的应用程序代码不妨碍的情况下访问他们的数据。这是 RDMBS 的真正力量和优势,也是使系统集成成为可能的原因。

但是,如果您的所有规则都存储在应用程序中,那么您的用户将需要非常小心他们如何操作数据库,以免导致应用程序崩溃。如果您指定关系约束和参照完整性,则需要其他应用程序以对任何将要使用它的应用程序有意义的方式修改数据。逻辑与数据(它所属的位置)而不是应用程序相关联。

请注意, MySQL在引用完整性方面是绝对的。当您尝试将空日期插入具有约束的日期时间字段时,通常会插入明显无效的值,例如今天的日期时间,它往往会默默地成功而不是抛出错误not null default null。DBA 说 MySQL 是个笑话是有充分理由的。

于 2013-01-01T06:13:04.870 回答
0

外键强制参照完整性。外键约束将防止您或任何其他用户在表中错误地添加不正确的记录。它确保在外键中输入的数据 (ID) 确实存在于引用表中。如果一些错误的客户端代码试图插入不正确的数据,那么在外键约束的情况下会引发异常,否则如果约束不存在,那么您的数据库将最终得到不一致的数据。

于 2013-01-01T05:46:14.240 回答
0

我能想到的使用外键的一些优点:

  • 使表之间的数据保持一致,防止出现坏数据(例如表A有一些记录引用表B中不存在的东西)

  • 帮助记录我们的数据库

  • 一些框架是基于外键生成领域模型的

于 2013-01-01T06:08:31.083 回答