外键,是一种保障数据一致性的手段,这是我在大学课堂里学到知识。
但是在企业中我却被教导不要使用外键,这样会带来性能上的问题。
不使用外键的话,这样外键带来的一系类好处都要我自己来做,比如说,在一张关联表中,如果我要插入一条关联关系a,b。a,b是逻辑外键(没有使用外键的伪外键)。那么我在插入的时候,首先要检查a,b是否存在于相关联的两张表。
这样原本交给数据库做的事情,现在由人工手动检查,毫无疑问,加重了人的成本。
所以接下来的探究便在于 在可以使用外键的情况下,sql性能是怎么样的。
那首先就要知道sql外键是怎么做到保持数据一致性的,也就是在做insert,update,delete的时候,外键是如何发挥效用的。
施工中… …未完待续