IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 为什么不推荐使用数据库级别外键 -> 正文阅读

[大数据]为什么不推荐使用数据库级别外键

阿里巴巴 Java 规范

【强制】不得使用外键与级联,一切外键概念必须在应用层解决。

数据库级别外键

??大家学习数据库的时候都学习过外键,使用外键有很多优点,最主要的优点就是:

  • 保证数据的完整性和一致性。
  • 将数据完整性判断交给数据库完成,减少程序的代码量,减少程序员工作量。

??使用外键可以减少程序员工作量,真是个好东西,但是现实却总是事与愿违。外键确实可以保证数据的完整性和一致性,但却伴随着一系列系统缺陷。权衡后,我们选择一般不使用数据库级别外键,除非你的 leader 要求使用。

缺陷

  • 使用数据库时需要考虑外键约束,增加麻烦。
  • 数据库工作量增加,影响数据库性能
  • 每次插入数据需要查询对应所有外键表中是否有数据,开销较大。可改为由程序员控制、优化查询,优化数据库,减少数据库的消耗。
  • 每次查询对应外键表时进行锁定,增加高并发系统死锁风险
  • 在进行数据库迁移和备份的时候依赖特定数据库,改为程序控制可以增加可移植性

应用层级别外键约束

??外键逻辑: 一张表去引用其他的表的数据。
??应用层实现: 程序员使用程序去控制查询对应外键表,代替数据库外键。

最佳实践

  • 数据库就是单纯的表,只用来存取数据。
  • 需要使用外键约束,使用程序去替代数据库外键,在应用层实现外键。
  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-10-28 12:27:20  更:2021-10-28 12:29:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 4:34:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码