目录
为什么不用外键约束
缺点
优点
禁用外键约束的原因
1.插入数据需要检查外键在引用的表是否存在,导致性能问题
2.并发读取会将要更改的page pin起来外键会被频繁检查,导致一直被锁定
pinned page在全部schedule操作执行完毕前不会应用到数据库,过多并发排队会导致崩溃
从而导致实际写入的表也就是订单明细表的,所有写操作未提交到DB而且崩溃
3.由于外键约束的级连删除
会导致在其他表引用该值的地方被一并删除,导致删除操作的结果不可控
4.Trigger
5.如果依赖外键关联来实现数据的一致性校验,会导致一旦需要迁移数据或升级DB软件时
需要改写应用来使应用对数据进行校验,还不如一开始就把数据校验交给应用完成。