1NF:原子性:字段不可以再分;
2NF、不存在部分依赖; 不可以把多种数据保存在同一张表中,即一张表只能保存“一种”数据 。外键关联
不符合第二范式的表:学号, 姓名, 年龄, 课程名称, 成绩, 学分;
可能会存在问题: 数据冗余,每条记录都含有相同信息;
删除异常:删除所有学生成绩,就把课程信息全删除了;
插入异常:学生未选课,无法记录进数据库;
更新异常:调整课程学分,所有行都调整。
正确做法:
学生:Student(学号, 姓名, 年龄); 课程:Course(课程名称, 学分); 选课关系:StudentCourse(学号, 课程名称, 成绩)。
3NF、直接性,每一列都和主键直接相关,而不能间接相关。(依赖不准传递) ,外键关联。
不符合第三范式的表: 学号, 姓名, 年龄, 学院名称, 学院电话,因为存在依赖传递: (学号) → (学生)→(所在学院) → (学院电话) 。
可能会存在问题:
数据冗余:有重复值;
更新异常:有重复的冗余信息,修改时需要同时修改多条记录,否则会出现数据不一致的情况
正确做法: 学生:(学号, 姓名, 年龄, 所在学院); 学院:(学院, 电话)。
本文来自 chenyyhh92 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/chenyyhh92/article/details/51174343?utm_source=copy