我的经验告诉我,很多数据库(大多数我曾经使用的)不包含外键时并不总是一件坏事。在这篇文章中,我想把重点放在为什么的原因上。

为什么这是一个问题?

1.潜在的数据完整性问题,

缺少外键明显问题是数据库不能强制进行引用完整性检查,如果在高一层没有正确处理,则可能会导致数据不一致(子行没有相应父行)。

2.表格关系不清晰

数据库中缺少外键的另一个不太明显的负面影响是,不了解该模式的人很难找到正确的表并找出表关系。这可能会导致严重的数据库查询和报告问题。

为什么数据库可以没有外键?

让我们来看看数据库可以没有外键的原因。首先一个简短的免责声明(因为文章引发了一些关于LinkedIn群体的争议):

下面的理由绝不鼓励不要在数据库中使用外键约束。这仅仅是我在各种渠道(主要是互联网论坛)都能找到的许多开发人员、架构师为什么不使用它们的理由。

我个人(和许多其他经验丰富的数据库专家)建议在任何可能的地方使用它们(不会导致更多的问题)。

1.性能

在表上拥有活动的外键可以提高数据质量,但会影响插入、更新和删除操作的性能。在这些任务之前,数据库需要检查它是否违反数据完整性。这就是为什么一些架构师和DBA完全放弃外键的原因。

数据仓库和分析数据库尤其如此,这些数据仓库和分析数据库不以交易方式(一次一行)处理数据,而是批量处理数据。性能是数据仓库和商业智能的一切。

2.传统数据

许多数据库在设计时需要存储来自旧数据库和遗留数据,这些数据可能对数据质量和完整性没有那么严格。为了能够容纳旧的脏数据,架构师可以选择a)清理和转换遗留数据(昂贵的练习),或者b)放弃在数据库级别上强制执行参照完整性。一些打包的ERP和CRM应用程序也使用这种方法。

3.全表重新加载

一些数据库,如数据仓库,分段或接口数据库,需要经常从外部重新加载数据。这会导致重新加载时数据不一致(在父表为空的情况下,子表可能已满载)。这可以通过在重新加载时禁用外键来绕过。

然而,这引入了额外的逻辑和复杂性以及另一个失败点。如上所述,对性能有负面影响。通常,成本大于收益,开发人员不用担心外键。

4.更高层次的框架

一些应用程序使用编程框架,在物理数据库之上创建另一个逻辑层。开发人员不使用插入或更新语句来修改数据,而使用API或者框架在后台执行所有操作。ORM(对象关系映射)框架或Ruby on Rails框架就是这种情况。

这些工具负责参照完整性,并与RDBMS一起创建更高级别的数据库引擎。这些框架可以自己创建数据库表,而不总是创建外键。使用这些工具的开发人员很少会干扰自动生成的模式,并且不需要外键。

5.跨数据库关系

这可能不是数据库没有外键的正确理由,一些数据库跨越更多的物理数据库甚至引擎,并且在技术上可能不能创建跨越数据库的它不能在同一台服务器上的两个数据库上创建key。

SQL Server就是一个很好的例子 - 它不能在同一台服务器上的两个数据库上创建key。而且这种架构在大型系统中很常见。

6.数据库平台不可知论者

类似于前一个,一些应用程序被设计为数据库平台(DBMS)不可知的,并能够在Oracle,SQL Server,DB / 2或Sybase等各种数据库上工作。

这是我读过的有关PeopleSoft(目前由Oracle拥有)的内容。设计人员不想绑定到任何特定的平台,并将所有逻辑推送到应用程序层,尽可能清楚地离开数据库层。

7.对更改开放

我与Oracle一直保持紧密联系,我听说过另一个关于其应用程序的故事,这是Oracle自己的产品 - Oracle电子商务套件 - 就是它被设计成尽可能定制。

Oracle提供了坚实的基础,使实施团队具有弹性,可以尽可能多地决定设计。至少这是他们所说的。也许这个原因和以前一样,或者是下一个原因:

8.懒惰的架构师

在创建数据库时,如果要存储数据,则需要创建一些表和列。这是最低限度。但是,您不必创建保持数据一致性的结构,如主键,唯一键,外键或约束。

这需要一些努力,但是却没有带来直接的好处。一些架构师和数据库管理员只是忽略了这一部分。

9.保持模型的秘密

也许这是一个很遥远的问题,但也许有时候是因为人们不希望别人知道太多太容易。一般来说,人们希望被需要和不可替代。一个完美的自我解释的设计可能会使他们过时。但这只是我的理论。

来源:www.jdon.com/49188

数据库不推荐使用外键的9个理由!相关推荐

  1. 数据库不推荐使用外键的9个理由

    为什么使用外键? 1.潜在的数据完整性问题, 缺少外键明显问题是数据库不能强制进行引用完整性检查,如果在高一层没有正确处理,则可能会导致数据不一致(子行没有相应父行). 2.表格关系不清晰 数据库中缺 ...

  2. 【原创】数据库中为什么不推荐使用外键约束

    引言 其实这个话题是老生常谈,很多人在工作中确实也不会使用外键.包括在阿里的JAVA规范中也有下面这一条 [强制]不得使用外键与级联,一切外键概念必须在应用层解决. 但是呢,询问他们原因,大多是这么回 ...

  3. 为什么数据库不应该使用外键?

    当我们想要持久化地存储数据时,使用关系型数据库往往都是最稳妥的选择,这不仅因为今天的关系型数据库种类非常丰富并且稳定,还因为不同社区对关系型数据库的支持都非常完备. 我们在前面的文章中曾经分析过 为什 ...

  4. 实际开发中,是否会在数据库表中设置外键?

    本科学习数据库的时候,书上明确的写了对于多对多关系必须要创建外键,可是最近在跟师兄做一个B/S架构的项目,发现所设计的数据库表虽然是多对多关系但并没有要求外键,查了一下之后才发现目前的大型系统中(尤其 ...

  5. 为什么数据库不应该使用外键

    为什么这么设计(Why's THE Design)是一系列关于计算机领域中程序设计决策的文章,我们在这个系列的每一篇文章中都会提出一个具体的问题并从不同的角度讨论这种设计的优缺点.对具体实现造成的影响 ...

  6. 数据库表设计索引外键设计_关于索引的设计决策 数据库管理系统

    数据库表设计索引外键设计 Introduction: 介绍: The attributes whose values are required inequality or range conditio ...

  7. 数据库建表需要外键约束?

    数据库建表需要外键约束吗? 数据库建表时一定要设置外键约束关系吗?

  8. mysql一对一外键约束_MySQL数据库之-foreign key 外键(一对多、多对多、一对一)、修改表、复制表...

    我们在同一数据库创建的表时候,很多时候会出现相同数据的冗余问题,也就是说几个id会有一个或者同n个相同字段,这样就导致数据表结构数据重复冗余, 冗余还无所谓,关键是如果我要改其中一个相同的字段信息,其 ...

  9. 数据库建表需要外键约束吗?

    建立外键的好处:  1) 由数据库保证数据完整性,比程序保证完整性更可靠,  多应用时(如有应用A,B,C他们之间的实体存在关联关系),由程序来保证数据完整性变得困难  2) 外键约束使得数据库的ER ...

最新文章

  1. 【CVPR 2020】神经网络架构搜索(NAS)论文和代码汇总
  2. Nature封面:脑机接口重大突破!意念手写字速度破纪录!
  3. 什么是python-三分钟了解什么是Python?python环境搭建
  4. DB2数据库常用工具
  5. Struts2 (三)OGLN
  6. 方舟原始恐惧mod生物代码_主播在《方舟生存进化》成功打造幽灵城堡,可怕的怪物在这里横行...
  7. 定义工厂(Plant)
  8. 修改Bugzilla的主页图片
  9. 解题报告-Leecode 563. 二叉树的坡度——Leecode每日一题系列
  10. Message Decoding密码翻译
  11. 将“早期版本的Windows”改名
  12. Tomcat修改默认端口号
  13. 新唐 Nuvoton ML51PC 入门 点亮板载LED
  14. 001_扎马步_初识hadoop
  15. 如何写好绩效考核的年终总结?分享一些技巧
  16. 每周一喂丨网络黑灰产工具“八大样儿”
  17. Zookeeper 深入进阶 —— ZAB 协议
  18. 水清冷冷:PSCC2019/PSCC2020安装教程和学习技巧(附工具)
  19. Python图片处理模块PIL操作方法(pillow)(转载)
  20. 冒着被打风险,揭秘软件测试工程师面试套路和暗语

热门文章

  1. 我们一般的前端开发流程
  2. JavaEE 资源注入
  3. cmd 一键获取 所有连接过的wifi 密码
  4. putty network error: connection refused
  5. C# 使用正则表达式去掉字符串中的数字,或者去掉字符串中的非数字
  6. linux cut 用法
  7. 10个强大的Ajax jQuery文件上传程序
  8. 网络营销的探索与爆发
  9. Android短信验证
  10. mysql创立不了数据库_以下不属于MySQL安装时自动创建的数据库是( ) (5.0分)_学小易找答案...