数据库性能优化之冗余字段的作用

作为初学者看到这章表是回答不出什么问题,其实从现实生活中来讲,这的确没什么问题的,记得念中学的时候,每次考完试,心里都很着急,急什么呢?当然是成绩,想想那个时候老师又是怎样把你的成绩信息给列出来的呢?是不是以这样的方式,每个班,甚至整个学校的学生成绩都是使用一张表来列出来的,而我们每个人的成绩利用该表中的一行数据来表示的,其中包括一个学生的学号,姓名,班级,成绩以及排名等等。而这里我们只是专业化成了数据库,一个班级的学生成绩变成了数据库中的一张表,而每个学生的成绩变成了表中的一条记录而已,所以认为没什么问题。但是对数据库的设计来讲,概念就不一样了,这样设计就会很容易出现很多问题。会出现一下什么问题呢。比如像增加异常,删除异常,更新异常等等,下面是几个例子。

eg1:在增加数据的时候,可能发生错误。这叫增加异常
  再仔细看上面这张表,在插入最后一条数据的时候,其中插入的班级和前面的不同,即“1班”,这从业务上来讲,当然没什么问题,但是从数据库的角度来讲,确是两个完全不同的概念,你可以认为是数据库本身太笨了吧,所以这个时候插入的数据,会给我们带来不必要的错误,这种错叫做增加异常。

eg2:在删除数据时,可能会删除相关的其它数据,这叫删除异常
这句话怎么理解呢?同样,看上面eg1的表,如果我们现在要指定删除班级为“一班”的班级怎么办?这个时候我们使用delete 学生成绩表 where 班级=‘一班’ 的话,就删除了班级='一班’的这些记录,这个时候,不是也给我们带来了不必要的后果吗?这就是删除异常。

eg3:在更新数据的时候,可能会有数据没有更新到。这叫更新异常。

你可能感兴趣的:(数据库性能优化之冗余字段的作用)