数据库外键的使用
来源:互联网 发布:apache虚拟主机不生效 编辑:程序博客网 时间:2024/05/16 09:16
在知乎上看到了一位圈友分享的关于外键使用的一些分析:
外键是否采用看业务应用场景,以及开发成本的,大致列下什么时候适合,什么时候不适合使用:
1. 互联网行业应用不推荐使用外键: 用户量大,并发度高,为此数据库服务器很容易成为性能瓶颈,尤其受IO能力限制,且不能轻易地水平扩展;
若是把数据一致性的控制放到事务中,也即让应用服务器承担此部分的压力,而引用服务器一般都是可以做到轻松地水平的伸缩;
2.传统行业
1>.软件应用的人数有限,换句话说是可控的;
2>.数据库服务器的数据量也一般不会超大,且活跃数据有限;综合上述2句话描述,也即数据库服务器的性能不是问题,所以不用过多考虑性能的问题;
另外,使用外键可以降低开发成本,借助数据库产品自身的触发器可以实现表与关联表之间的数据一致性和更新;
最后一点,使用外键的方式,还可以做到开发人员和数据库设计人员的分工,可以为程序员承担更多的工作量;
为何说外键有性能问题:
1.数据库需要维护外键的内部管理;
2.外键等于把数据的一致性事务实现,全部交给数据库服务器完成;3.有了外键,当做一些涉及外键字段的增,删,更新操作之后,需要触发相关操作去检查,而不得不消耗资源;
4.外键还会因为需要请求对其他表内部加锁而容易出现死锁情况;
作者:mysqlops
链接:https://www.zhihu.com/question/19600081/answer/13295957
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
0 0
- 数据库外键的使用
- 数据库外键的使用
- 数据库外键的使用
- 数据库外键的使用
- 数据库外键的使用
- 数据库外键的使用
- 数据库外键的使用
- 谈谈数据库外键的使用
- 数据库外键的使用以及优缺点
- 数据库外键的使用以及优缺点
- 数据库外键的使用以及优缺点
- 数据库外键的使用以及优缺点
- 数据库外键的使用和原则
- 数据库外键的使用以及优缺点
- 数据库外键的使用和原则
- 数据库外键的使用和原则
- 数据库外键使用优缺点
- 数据库外键使用优缺点
- sql server 中输入英文语句出现错误时
- Redis安装及使用过程中遇到的问题
- BZOJ 1683: [Usaco2005 Nov]City skyline 城市地平线 还是单调栈。。。
- 什么是存储转发技术
- SSL 1636——城市交通
- 数据库外键的使用
- 花拉子模信使问题(王小波)
- leetcode 148. Sort List
- Jquery——Day4(Ajax基本用法get/post/ajax/serialize等)
- 城市交通-SSL 1636
- jQuery延迟函数 让DIV延时几秒后消失或显示
- IOS缓存管理之PINCache使用
- 网站一定要增加友情链接吗?
- 【C#基础】——初识