【表设计】外键的取舍-分布式中逐渐消失的外键

在分布式大行其道的今天,为什么外键约束越来越少?

外键-数据链接带来强制完整性

在关系型数据库中,外键(Foreign Key)可以用于建立和强制两个表之间的数据链接。

层次数据结构一篇的闭包表简单设计中,就有使用外键进行数据链接。

像这样:

我们很容易发现,外键最直接的体现是强制完整性,即引用表中的外键值必须先存在于被引用表。

删除被引用的行数据时,必须先删除引用表数据(级联删除)。

通过外键,我们很容易理清楚表之间的关系,即理解数据模型,且也有利于ER图的生成和可视化。

外键-强制完整性不适应微服务

分布式与微服务追求服务的自洽 ,要求服务具备独立性,要求架构整体具备容错,服务之间不会互相阻塞。

这些与外键的强制关联特性相冲突。

且在数据库与服务基本是N对N的环境下,数据库外键约束通常无法跨越不同的数据库实例或服务边界 来强制执行。

另外数据库每次执行外键操作还需要额外的检查来验证外键约束。在高并发、高写入吞吐量的场景下,这样的额外开销可能会成为性能瓶颈。

因此,高耦合强制的外键,并不适应现在主流的微服务、分布式。

应用层处理代替外键约束

外键不合适了,但是外键要做的事情却不能不做,常见的做法是在应用层完成外键原本的工作。

  • 数据链接

    在执行删除或更新操作前,应用程序代码需要检查是否存在关联数据。

    通过逻辑删除,保留数据的链接。

  • 数据稽核

    建立一个稽核系统,处理数据的不一致与孤儿数据(在引用表有数据,被引用表没有数据)。

相关推荐
星之尘10217 小时前
“粽”览全局:分布式系统架构与实践深度解析(端午特别版)
分布式·spring cloud·微服务·系统架构·kubernetes·serverless·可用性测试
寻找沙漠的人12 小时前
RabbitMQ 高级特性
分布式·rabbitmq
陈逸轩*^_^*12 小时前
如何在 Ubuntu22.04 上安装并开始使用 RabbitMQ
分布式·rabbitmq
Tom Boom12 小时前
43. 远程分布式测试实现
分布式·测试开发·自动化·webdriver·自动化测试框架开发·分布式测试
深夜的螺蛳粉15 小时前
分布式事务之事务消息
分布式
快乐肚皮17 小时前
Redisson学习专栏(四):实战应用(分布式会话管理,延迟队列)
分布式·学习·redisson·延迟队列·分布式会话
纪元A梦17 小时前
分布式流处理与消息传递——Kafka ISR(In-Sync Replicas)算法深度解析
java·分布式·算法·kafka
我的golang之路果然有问题19 小时前
RabbitMQ-Go 性能分析
笔记·分布式·后端·学习·golang·rabbitmq
卡布奇诺-海晨20 小时前
Redis分布式锁深度解析与最佳实践
数据库·redis·分布式
Watink Cpper1 天前
[Redis] Redis:高性能内存数据库与分布式架构设计
linux·数据库·redis·分布式·架构