为什么数据库要三大范式:
这里可以将三大范式理解为:设计数据库时需要遵循的规则,可以有效的帮助我们建立冗余小且结构合理的数据库。
第一范式
原子性:确保每列的原子性(强调的是列的原子性,即列不能够再分成其他几列)不可再分解
第二范式
唯一性:,第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关,要求记录有唯一标识,不存在部分依赖
第三范式
冗余性:在第二范式的基础上更进一层,目标是确保每列都和主键列直接相关,而不是间接相关,它要求字段没有冗余,即不存在传递依赖
反范式
规范化的优点是明显的,它避免了大量的数据冗余,节省了存储空间,保持了数据的一致性。当一个库里的数据经常发生变化时,达到3NF的库可以使用户不必在超过两个以上的地方更改同一个值。那么是不是只要把所有的表都规范为3NF后,数据库的设计就是最优的呢?这可不一定。范式越高意味着表的划分更细,一个数据库中需要的表也就越多,用户不得不将原本相关联的数据分摊到多个表中。当用户同时需要这些数据时只能采用连接表的形式将数据重新合并在一起。同时把多个表联接在一起的花费是巨大的,尤其是当需要连接的两张或者多张表数据非常庞大的时候,表连接操作几乎是一个噩梦,这严重地降低了系统运行性能。