数据库三范式通俗说法,书上说的太蛋疼
2016-04-17 18:16
218 查看
简单来说三句话:
1NF、列不可分;
2NF、不存在部分依赖;
3NF、不存在传递依赖。
解释:
1NF:原子性,即字段不可以再分。
2NF:唯一性,不可以把多种数据保存在同一张表中,即一张表只能保存“一种”数据。
不符合第二范式的表:学号, 姓名, 年龄, 课程名称, 成绩, 学分;
可能会存在问题:
数据冗余,每条记录都含有相同信息;
删除异常:删除所有学生成绩,就把课程信息全删除了;
插入异常:学生未选课,无法记录进数据库;
更新异常:调整课程学分,所有行都调整。
正确做法:
学生:Student(学号, 姓名, 年龄);
课程:Course(课程名称, 学分);
选课关系:StudentCourse(学号, 课程名称, 成绩)。
3NF:直接性,每一列都和主键直接相关,而不能间接相关。(依赖不准传递)
不符合第三范式的表: 学号,
姓名, 年龄, 学院名称, 学院电话,因为存在依赖传递: (学号) → (学生)→(所在学院) → (学院电话) 。
可能会存在问题:
数据冗余:有重复值;
更新异常:有重复的冗余信息,修改时需要同时修改多条记录,否则会出现数据不一致的情况
正确做法:
学生:(学号, 姓名, 年龄, 所在学院);
学院:(学院, 电话)。
1NF、列不可分;
2NF、不存在部分依赖;
3NF、不存在传递依赖。
解释:
1NF:原子性,即字段不可以再分。
2NF:唯一性,不可以把多种数据保存在同一张表中,即一张表只能保存“一种”数据。
不符合第二范式的表:学号, 姓名, 年龄, 课程名称, 成绩, 学分;
可能会存在问题:
数据冗余,每条记录都含有相同信息;
删除异常:删除所有学生成绩,就把课程信息全删除了;
插入异常:学生未选课,无法记录进数据库;
更新异常:调整课程学分,所有行都调整。
正确做法:
学生:Student(学号, 姓名, 年龄);
课程:Course(课程名称, 学分);
选课关系:StudentCourse(学号, 课程名称, 成绩)。
3NF:直接性,每一列都和主键直接相关,而不能间接相关。(依赖不准传递)
不符合第三范式的表: 学号,
姓名, 年龄, 学院名称, 学院电话,因为存在依赖传递: (学号) → (学生)→(所在学院) → (学院电话) 。
可能会存在问题:
数据冗余:有重复值;
更新异常:有重复的冗余信息,修改时需要同时修改多条记录,否则会出现数据不一致的情况
正确做法:
学生:(学号, 姓名, 年龄, 所在学院);
学院:(学院, 电话)。
相关文章推荐
- 数据库范式通俗解释
- ubuntu下修改mysql编码格式的问题
- Mysql 表的增删改sql语句
- 全新安装Mac OSX 开发者环境 同时使用homebrew搭建 PHP,Nginx ,MySQL,Redis,Memcache ... ... (LNMP开发环境)
- 链接sql数据库并输出csv文件
- MySQL入门很简单: 10 mysql运算符
- mongodb入门很简单(1)
- mybatis,sqlserver分页
- mysql中的主要的参数
- SQLite 约束
- mysql插入数据后返回自增ID的方法
- MySQL入门很简单: 9 插入 更新与删除数据
- mac ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib /mysql/mysql.sock' (111)
- xmpp开发IM即时通讯系列(二)--即时通讯服务器搭建(1)数据库搭建
- SQL分页语句
- oracle误删表解决方案
- Marklogic学习 由浅入深(A)—— Marklogic与MongoDB区别
- 异常 SQLErrorCodes loaded: [DB2, Derby, H2, HSQL, Informix, MS-SQL, MySQL, Oracle, PostgreSQL, Sybase]
- mysql监控
- SQL绑定变量