三大范式和E-R图

一. 范式

数据库的范式是一组规则 。在设计数据库时,遵从不同的规范要求,设计出合理的关系型数据库,这些不同的规范要求被称为不同的范式。

1. 第一范式

定义

数据库表的每一列都是不可分割的原子数据项,而不能是集合,数组,对象等非原子数据。

在关系型数据库的设计中,满足第一范式的是对关系型的基本要求。不能满足第一范式的数据库不能被称为关系型数据库。

反例

正例

2. 第二范式

定义

在满足第一范式的基础上,不存在非关键字段对任意候选键的部分函数依赖。存在于表中定义了复合主键的情况下。

候选键:可以唯一标识一行数据的列或列的组合,可以从候选键中选一个或多个当做表的主键。

反例

正例

不满足第二范式会出现的问题

数据冗余

更新异常

插入异常

删除异常

3. 第三范式

定义

在满足第二范式的基础上,不存在非关键字段,对任意候选键的传递依赖

反例

正例

二. 实体-关系图

简称E-R图,也称作实体联系模型、实体关系模型,是一种用于描述数据模型的概念图,主要用于数据库设计阶段。

关系的类型

一对一关系

⼀个⽤⼾实体包含的属性有:⽤⼾昵称,真实姓名,⼿机号,邮箱地址,性别,学校

⼀个账⼾实体包含的属性有:登录⽤⼾名,密码

⽤⼾实体与账⼾实体是⼀对⼀的关系,⽤E-R图表⽰如下

一对多关系

⼀个学⽣实体包含的属性有:真实姓名,学号,年龄,性别,⼊学时间

⼀个班级实体包含的属性有:班级名,学⽣⼈数

⼀个班级中有多个学⽣,所以班级实体与学⽣实体是⼀对多的关系,反过来说学⽣实体与班级实体 是多对⼀着么,⽤E-R图表⽰如下:

多对多关系

⼀个学⽣实体包含的属性有:真实姓名,学号,年龄,性别,⼊学时间

⼀个课程实体包含的属性有:课程名

⼀个学⽣可以选修改多⻔课程,⼀⻔课程也可以被多名学⽣选修改,所以学⽣与课程之间是多对多 关系,⽤E-R图表⽰如下:

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

三. 逆向查看EE-R图

当表创建完成,并设置了正确的主外键关系之后,可以通过可视化客⼾端⼯具的逆向⽣成数据库模 型(EE-R图)

客⼾端⼯具可以使⽤Workbench或Navicat(收费功能)

相关推荐
坚定信念,勇往无前34 分钟前
electron-vite 安装better-sqlite3
javascript·数据库·electron
大明者省39 分钟前
Ubuntu22.04 宝塔面板与 XFCE 远程桌面端口兼容性分析
运维·服务器·数据库·笔记
liudanzhengxi1 小时前
巧用ULN2003A轻松扩展单片机IO口
数据库·mongodb
Teable任意门互动1 小时前
深度解析:AI 赋能开源多维表格,实现企业全场景数据整合与高效应用
数据库·人工智能·低代码·信息可视化·开源·数据库开发
DevOpenClub2 小时前
职教高考及高职分类招生控制线 API 接口
java·数据库·高考
funnycoffee1232 小时前
华为S5736交换机3层ECMP负载方式
linux·服务器·数据库
添砖java‘’2 小时前
MySQL复合查询
数据库·mysql
星川水月2 小时前
Access数据库快速入门——外部数据导入和SQL简单查询
数据库·sql·access
清平乐的技术专栏2 小时前
一文读懂Kafka中的“消费”(对标MySQL数据库)
数据库·mysql·kafka