博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据库范式简单理解
阅读量:6587 次
发布时间:2019-06-24

本文共 656 字,大约阅读时间需要 2 分钟。

  hot3.png

1NF:原子性:字段不可以再分;

24222153_uJ3l.jpg

2NF、不存在部分依赖; 不可以把多种数据保存在同一张表中,即一张表只能保存“一种”数据 。外键关联

不符合第二范式的表:学号, 姓名, 年龄, 课程名称, 成绩, 学分; 

可能会存在问题: 数据冗余,每条记录都含有相同信息; 

删除异常:删除所有学生成绩,就把课程信息全删除了; 

插入异常:学生未选课,无法记录进数据库; 

更新异常:调整课程学分,所有行都调整。 

正确做法: 

学生:Student(学号, 姓名, 年龄);  课程:Course(课程名称, 学分);  选课关系:StudentCourse(学号, 课程名称, 成绩)。 

3NF、直接性,每一列都和主键直接相关,而不能间接相关。(依赖不准传递) ,外键关联。

不符合第三范式的表: 学号, 姓名, 年龄, 学院名称, 学院电话,因为存在依赖传递: (学号) → (学生)→(所在学院) → (学院电话) 。

可能会存在问题:

数据冗余:有重复值; 

更新异常:有重复的冗余信息,修改时需要同时修改多条记录,否则会出现数据不一致的情况 

正确做法: 学生:(学号, 姓名, 年龄, 所在学院);  学院:(学院, 电话)。

91b79747308d00624fff5577626f044fc31.jpg

本文来自 chenyyhh92 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/chenyyhh92/article/details/51174343?utm_source=copy

 

转载于:https://my.oschina.net/GJB/blog/2208155

你可能感兴趣的文章
一些出的不错的Java面试题(一)
查看>>
记一次omi的项目之旅
查看>>
Android API级别、代号、发布时间及平台亮点整理
查看>>
Redis数据类型(上)
查看>>
安装配置nagios
查看>>
QQ第三方授权登录(带详细源码)
查看>>
HBase
查看>>
string 转换int
查看>>
rsync详解
查看>>
rsync通过服务同步、linux日志、screen工具
查看>>
吸血鬼教授vs狼人工程师
查看>>
LLDP(链路层发现协议)
查看>>
中国区Azure基本实例更新
查看>>
CentOS 6.5 Zabbix监.控系统功能及基本使用
查看>>
Ubuntu14 添加程序启动
查看>>
我的友情链接
查看>>
常见数据类型的手机二维码生成与识别格式参考
查看>>
windows网络安全以及常见网络***方式
查看>>
警告 初始化默认驱动器时出错“找不到运行 Active Directory Web 服务的默认服务器。”...
查看>>
Irssi Error [Cannot assign requested address: x.x.x.x]
查看>>