黑马程序员技术交流社区

标题: 数据库设计是否需要外键? [打印本页]

作者: 神马王刚    时间: 2012-10-14 01:20
标题: 数据库设计是否需要外键?
本帖最后由 神马王刚 于 2012-10-15 19:11 编辑

数据库设计是否需要外键?这里有两个问题:一个是如何保证数据库数据的完整性和一致性;二是第一条对性能的影响。而听人说要尽量少使用外键,为何?
作者: 郭会茹    时间: 2012-10-14 08:57
要你数据库设计合理,使用合法,可以不需要外键:外键是将B表的某列和A表的主键连接起来。A的主键是id,那么就是它了。


作者: 谷黎明    时间: 2012-10-14 11:14
设计数据表主外键关系,一般是为了处理1-多数据关系,例如:客户-订单关系。1个客户对应多个订单,一个订单只有一个唯一客户。显然是1-多关系。


作者: 雷向阳    时间: 2012-10-14 11:21
黑马视频老师说可以不用设置外键,但是我觉得还是设置好不容易出错...
作者: 刘俊红    时间: 2012-10-14 17:36
可以不用设外键,特别是在Web应用中。
这是著名DBA冯大辉 Fenng 的说法。 他前一个公司是支付宝。
怎么总有人问我数据库的问题...

透露一个秘密,我在前公司的时候摘掉了所有的外键。业务约束通过中间层控制。面向Web的应用应该这样。

一个DBA是否有足够的设计能力,就看他有多大的能力做反范式设计就可以了。不要问为什么。http://zhi.hu/Ik5z


作者: 邸亚星    时间: 2012-10-14 21:59
外键要适当,不能过分追求。在大型系统中性能要求不高的安全要求高的可以使用外键小系统最好用外键




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2