A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 神马王刚 中级黑马   /  2012-10-14 01:20  /  2190 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 神马王刚 于 2012-10-15 19:11 编辑

数据库设计是否需要外键?这里有两个问题:一个是如何保证数据库数据的完整性和一致性;二是第一条对性能的影响。而听人说要尽量少使用外键,为何?

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

5 个回复

倒序浏览
要你数据库设计合理,使用合法,可以不需要外键:外键是将B表的某列和A表的主键连接起来。A的主键是id,那么就是它了。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
设计数据表主外键关系,一般是为了处理1-多数据关系,例如:客户-订单关系。1个客户对应多个订单,一个订单只有一个唯一客户。显然是1-多关系。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
黑马视频老师说可以不用设置外键,但是我觉得还是设置好不容易出错...
回复 使用道具 举报
可以不用设外键,特别是在Web应用中。
这是著名DBA冯大辉 Fenng 的说法。 他前一个公司是支付宝。
怎么总有人问我数据库的问题...

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

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

回复 使用道具 举报
外键要适当,不能过分追求。在大型系统中性能要求不高的安全要求高的可以使用外键小系统最好用外键

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马