数据库处键的必要性

以下是个人和一些网友的看法,希望能起个抛砖引玉的作用

1.
规范化的数据库当然需要 FK, 没有 FK 何谈规范化? NF 是已经被被证明的理论

2.
但是,理论终归是理论,NF 一个重要目标就是避免数据冗余,
当冗余不存在的时候,查询就需要更多的操作,比如需要表链接,

3.
所以了,实际应用,一般只 3NF,并且有了 非规范化 或者 逆规范化 的设计

4.
设计 规范化 的数据库很容易,但是 逆规范化 的数据不是每个人都可以设计的,
一般,跟你的 实际需求目标 紧密关联的,至少冗余问题来了,你得考虑更新策略

5.
一般 3NF 就够了,
一般小型应用,还是严格到 3NF
只有大型应用,牛人们才考虑非规范化设计
如果,你连 规范化设计 都不理解,就不要奢望 非规范化设计了,前者是后者的基础

 

6 数据库"设计"需要外键,数据库"实现"不需要外键,只在程序里实现约束,

 

这个第6点的程序实现约束,大家都有哪些作法呢,我是每次手动写代码去判断的

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值