高并发场景下禁用外键的原因是什么?
高并发场景中禁用外键的真实实践
一些高并发项目中确实会禁用外键,这并非闻所未闻。这类场景通常涉及以下情况:
场景:分库分表
分库分表时,表会根据某些字段进行拆分,如果使用物理外键,则不同库或表之间的关联关系无法由数据库自动维护。
场景:业务扩展
为方便日后业务扩展,可能不使用物理外键。例如,两个实体之间的关联关系可能会随着业务发展而发生变化,使用物理外键会带来改表成本。
虽然禁用物理外键,但项目中仍然会维持业务层面的外键约束。
一致性保障
在这种情况下,数据一致性不再依赖数据库的外键机制,而是由业务层负责实现。例如,删除主表数据时,需要业务层操作关联表进行级联删除。
最终一致性考虑
需要注意的是,某些场景下只需要满足最终一致性,而不是强一致性。例如,电商订单支付成功后,需要将订单与其明细关联起来。即使关联操作没有立即执行,只要最终能够建立联系即可。
文章推荐
-
Python实现字典的key和values的交换
有些时候我们不得已要利用values来反向查询key,有没有简单的方法呢?下面我给大家列举一些方法,方便大家使用pyth...
Python
2个月前 (02-11) 210 -
使用Python脚本来获取Cisco设备信息的示例
今天发现一个使用python写的管理cisco设备的小框架tratto,可以用来批量执行命令。下载后主要有3个文件:Sy...
Python
2个月前 (02-11) 114 -
Python的Django中django-userena组件的简单使用教程
利用twitter/bootstrap,项目的基础模板算是顺利搞定。接下来开始处理用户中心。用户中心主要包括用户登陆、注...
Python
2个月前 (02-11) 102 -
零基础写python爬虫之神器正则表达式
接下来准备用糗百做一个爬虫的小例子。但是在这之前,先详细的整理一下Python中的正则表达式的相关内容。正则表达式在Py...
Python
2个月前 (02-11) 114 -
零基础写python爬虫之抓取百度贴吧代码分享
这里就不给大家废话了,直接上代码,代码的解释都在注释里面,看不懂的也别来问我,好好学学基础知识去! 代码如下:# -*-...
Python
2个月前 (02-11) 102
最新文章
- 微信三级分销系统产品详情页怎么开发? 4周前 (03-13)
- 微信公众号-获取用户信息(网页授权获取)实现步骤 4周前 (03-13)
- php微信公众号开发(2)百度BAE搭建和数据库使用 4周前 (03-13)
- php微信公众号开发(3)php实现简单微信文本通讯 4周前 (03-13)
- php微信公众号开发(4)php实现自定义关键字回复 4周前 (03-13)
- php版微信小店调用api示例代码 4周前 (03-13)
- php版微信小店API二次开发及使用示例 4周前 (03-13)
- C# 微信公众号开发--准备工作 4周前 (03-13)
- C#微信公众号开发--微信事件交互 4周前 (03-13)
- C#微信公众号开发--网页授权(oauth2.0)获取用户基本信息一 4周前 (03-13)