PHP前端开发

高并发场景下禁用外键的原因是什么?

百变鹏仔 4天前 #Python
文章标签 场景

高并发场景中禁用外键的真实实践

一些高并发项目中确实会禁用外键,这并非闻所未闻。这类场景通常涉及以下情况:

场景:分库分表

分库分表时,表会根据某些字段进行拆分,如果使用物理外键,则不同库或表之间的关联关系无法由数据库自动维护。

场景:业务扩展

为方便日后业务扩展,可能不使用物理外键。例如,两个实体之间的关联关系可能会随着业务发展而发生变化,使用物理外键会带来改表成本。

虽然禁用物理外键,但项目中仍然会维持业务层面的外键约束。

一致性保障

在这种情况下,数据一致性不再依赖数据库的外键机制,而是由业务层负责实现。例如,删除主表数据时,需要业务层操作关联表进行级联删除。

最终一致性考虑

需要注意的是,某些场景下只需要满足最终一致性,而不是强一致性。例如,电商订单支付成功后,需要将订单与其明细关联起来。即使关联操作没有立即执行,只要最终能够建立联系即可。