您的位置 首页 编程知识

高并发项目真的会禁止使用外键吗?

没有外键的项目真的存在吗? 对于高并发的项目,人们常说为了提升效率会禁止数据表使用外键。那么,这样的情况真的存…

高并发项目真的会禁止使用外键吗?

没有外键的项目真的存在吗?

对于高并发的项目,人们常说为了提升效率会禁止数据表使用外键。那么,这样的情况真的存在吗?如果存在,在什么场景下会出现?没有外键的情况下,相关实体数据的一致性是如何保障的?

答案:

是的,在高并发项目中禁止数据表使用外键的做法非常普遍。

禁止外键的原因:

在高并发系统中,为了应对海量,数据库分库分表是常见的手段。但在这种情况下,使用物理外键(即依赖数据库提供的外键特性)会存在性能问题和维护困难的问题。因此,这些项目一般会禁止使用物理外键。

数据一致性保障:

尽管禁止使用物理外键,但这些项目仍然需要保证相关实体数据的一致性。这靠业务层逻辑来实现,而不是交给数据库。

常见的处理方式:

例如,如果主表数据被删除,需要级联删除关联表中的相关记录。物理外键可以通过级联删除来轻松处理这一情况,而业务层处理则需要手动执行删除操作。其他涉及外键约束和级联更新的操作也需要以相同的方式处理。

最终一致性:

值得注意的是,在某些场景下,只需要“最终一致性”,即相关数据不需要实时同步,而是随着时间推移逐渐达到一致。这种情况下,手工维护数据一致性就变得可行。

以上就是高并发项目真的会禁止使用外键吗?的详细内容,更多请关注php中文网其它相关文章!

本文来自网络,不代表四平甲倪网络网站制作专家立场,转载请注明出处:http://www.elephantgpt.cn/3506.html

作者: nijia

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

18844404989

在线咨询: QQ交谈

邮箱: 641522856@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部