一. 范式
数据库的范式是一组规则 。在设计数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式。
1. 第一范式
定义
数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,对象等非原子数据。
在关系型数据库的设计中,满足第一范式的是对关系型的基本要求。不能满足第一范式的数据库不能被称为关系型数据库。
反例

正例

2. 第二范式
定义
在满足第一范式的基础上,不存在非关键字段对任意候选键的部分函数依赖。存在于表中定义了复合主键的情况下。
候选键:可以唯一标识一行数据的列或列的组合,可以从候选键中选一个或多个当做表的主键。
反例

正例



不满足第二范式会出现的问题
数据冗余
更新异常
插入异常
删除异常
3. 第三范式
定义
在满足第二范式的基础上,不存在非关键字段,对任意候选键的传递依赖。
反例

正例


二. 实体-关系图
简称E-R图,也称作实体联系模型、实体关系模型,是一种用于描述数据模型的概念图,主要用于数据库设计阶段。
关系的类型
一对一关系
⼀个⽤⼾实体包含的属性有:⽤⼾昵称,真实姓名,⼿机号,邮箱地址,性别,学校
⼀个账⼾实体包含的属性有:登录⽤⼾名,密码
⽤⼾实体与账⼾实体是⼀对⼀的关系,⽤E-R图表⽰如下

一对多关系
⼀个学⽣实体包含的属性有:真实姓名,学号,年龄,性别,⼊学时间
⼀个班级实体包含的属性有:班级名,学⽣⼈数
⼀个班级中有多个学⽣,所以班级实体与学⽣实体是⼀对多的关系,反过来说学⽣实体与班级实体 是多对⼀着么,⽤E-R图表⽰如下:


多对多关系
⼀个学⽣实体包含的属性有:真实姓名,学号,年龄,性别,⼊学时间
⼀个课程实体包含的属性有:课程名
⼀个学⽣可以选修改多⻔课程,⼀⻔课程也可以被多名学⽣选修改,所以学⽣与课程之间是多对多 关系,⽤E-R图表⽰如下:

对于多对多关系,可以使⽤中间表进⾏记录,⽐如⼀个学⽣参加了某⼀⻔课程的考试得到了相应的 成绩,⽤E-R图表⽰如下

三. 逆向查看EE-R图
当表创建完成,并设置了正确的主外键关系之后,可以通过可视化客⼾端⼯具的逆向⽣成数据库模 型(EE-R图)
客⼾端⼯具可以使⽤Workbench或Navicat(收费功能)
