◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。
高并发场景中禁用外键的真实实践
一些高并发项目中确实会禁用外键,这并非闻所未闻。这类场景通常涉及以下情况:
场景:分库分表
分库分表时,表会根据某些字段进行拆分,如果使用物理外键,则不同库或表之间的关联关系无法由数据库自动维护。
场景:业务扩展
为方便日后业务扩展,可能不使用物理外键。例如,两个实体之间的关联关系可能会随着业务发展而发生变化,使用物理外键会带来改表成本。
虽然禁用物理外键,但项目中仍然会维持业务层面的外键约束。
一致性保障
在这种情况下,数据一致性不再依赖数据库的外键机制,而是由业务层负责实现。例如,删除主表数据时,需要业务层操作关联表进行级联删除。
最终一致性考虑
需要注意的是,某些场景下只需要满足最终一致性,而不是强一致性。例如,电商订单支付成功后,需要将订单与其明细关联起来。即使关联操作没有立即执行,只要最终能够建立联系即可。
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。