用?不用?数据库外键约束之优缺点

有些同学可能还不清楚什么是主键和外键,那么简单先给大家过一遍。

什么是主键、外键?

  • 学生表(学号,姓名,性别,班级) 学号是一个主键
  • 课程表(课程号,课程名,学分) 课程号是一个主键
  • 成绩表(学号,课程号,成绩) 学号和课程号的属性组构成一个主键

成绩表中的学号不是成绩表的主键,不过是学生表的主键,成绩表的外键,同理课程号也是成绩表的外键

定义:如果公共关键字在一个关系中是主关键字,那么这个公共关键字被称为另一个关系的外键。以一个关系的外键作主关键字的表被称为主表,具有此外键的表被称为主表的从表

男人欢呼在钱台阶与键孔

好,那么外键的约束是否有用?又有哪些优缺点呢?

优点(用)

1.数据一致性

由数据库自身保证数据一致性,完整性,更可靠,因为程序很难100%保证数据 的完整性,而用外键即使在数据库服务器当机或者出现其他问题的时候,也能够最大限度的保证数据的一致性和完整性。

eg:数据库和应用是一对多的关系,A应用会维护他那部分数据的完整性,系统一变大时,增加了B应用,A和B两个应用也许是不同的开发团队来做的。他们如何协调保证数据的完整性,而且一年以后如果又增加了C应用呢?

2.ER图可靠性

有主外键的数据库设计可以增加ER图的可读性,这点在数据库设计时非常重要。

3.使设计更全面

外键在一定程度上说明的业务逻辑,会使设计周到具体全面

4.级联性能未必最低

除非能证明触发器的性能和可维护性比外键更优,否则凭什么一定要否定外键呢?

5.程序能完全保证安全性吗?

使用应用程序来维护数据完整性,则是严重降低数据库安全性的一种做法。连接字符串里如果有uid和pwd或者类似的这两个东西,可以使用工具获取你数据库的帐号。因为每次建立数据库联接的时候都会在网线上以标准格式传递这些信息。从此编码内的任何保证都是空的。

6.导致冗余

不使用外键,会导致数据冗余,在级联最底层的表可能会重复好几层的数据 必然导致最底层的表数据量翻倍,IO瓶颈是数据库性能瓶颈之一。

缺点(不用)

1.程序逻辑

某些程序逻辑中,程序的逻辑已经足够保证完整性,我会在存储过程或包等地方做严谨的判断;

2.性能问题

这是很多人不喜欢用的关键原因,比如一个业务流水表,频繁插入数据,如果这个表身上有3外键,那么每次插入一条,就必须对这3个外键对应的3个表做相应的查找判断有无对应数据,如果这3个表也很大,那就这3个表的判断时间就很常,虽然外键指向的关联表的字段肯定是索引,但是我觉得很多时候,这样的判断本来就在程序里控制好了,通过外键再判断一次,就是降低性能;而且其实有的地方判不判断也无所谓的,但是用了外键,就必须化时间去判断,无论oracle内部多么优化外键对于数据的检索速度,它总是一个不小的消耗;

3.维护麻烦

很多公司的软件都是定制的,这种定制的东西,随意性相对较大,项目开发实施过程中,需要经常对表修修补补;还有就是业务逻辑有bug或者其他情况,需要经常手工维护数据,有错综复杂的外键关联着,很是麻烦;

4.外键定死了先后生成关系

外键定死了两个表之间数据的先后生成关系,最常见的是单据主从表,有的时候,在生成单据的时候,是先生成明细,再生成主表;如果钉死了外键,这个就没法实现;

PS: 当然有些关键的业务,确实需要外键;

举报
评论 0