三大范式和E-R图

一. 范式

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

1. 第一范式

定义

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

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

反例

正例

2. 第二范式

定义

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

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

反例

正例

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

数据冗余

更新异常

插入异常

删除异常

3. 第三范式

定义

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

反例

正例

二. 实体-关系图

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

关系的类型

一对一关系

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

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

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

一对多关系

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

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

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

多对多关系

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

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

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

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

三. 逆向查看EE-R图

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

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

相关推荐
审判长烧鸡18 小时前
数据库字段命名规范速查表
数据库·sql
承渊政道18 小时前
【MySQL数据库学习】(MySQL表的内外连接)
数据库·学习·mysql·leetcode·bash·数据库开发·数据库系统
瀚高PG实验室18 小时前
db_ha集群中某个节点启动失败,报错缺少sm4加密模块
数据库·瀚高数据库·highgo
IvorySQL18 小时前
PostgreSQL 技术日报 (6月16日)|Neon 自动化再进一步,逻辑复制冲突日志迎来 v50 更新
数据库·postgresql·自动化
小小工匠18 小时前
Redis - 主从集群脑裂:数据丢失的隐藏杀手
数据库·redis
JAMSAN093018 小时前
机器人轴承:被低估的“物理关节”,正在打开300倍增长空间
数据库·人工智能·机器人·智能硬件
计算机安禾1 天前
【数据库系统原理】第19篇:计算机存储层次结构与数据库文件的物理组织
数据库·oracle
JAVA面经实录9171 天前
操作系统面试题
java·服务器·数据库·计算机网络·面试
摇滚侠1 天前
mariadb-libs 被 mysql-community-libs-5.7.28-1.el7.x86_64 取代
数据库·mysql·mariadb
DIY源码阁1 天前
JavaSwing饮品管理系统 - MySQL版
java·数据库·mysql·eclipse