三大范式和E-R图

一. 范式

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

1. 第一范式

定义

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

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

反例

正例

2. 第二范式

定义

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

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

反例

正例

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

数据冗余

更新异常

插入异常

删除异常

3. 第三范式

定义

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

反例

正例

二. 实体-关系图

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

关系的类型

一对一关系

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

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

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

一对多关系

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

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

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

多对多关系

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

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

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

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

三. 逆向查看EE-R图

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

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

相关推荐
快乐非自愿6 小时前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
这儿有一堆花6 小时前
住宅代理(Residential Proxy)技术指南
开发语言·数据库·php
茉莉玫瑰花茶7 小时前
LangChain 核心组件 [ 2 ]
java·数据库·langchain
存在的五月雨8 小时前
Mysql 索引的一些
数据库·mysql
黄俊懿8 小时前
MySQL主从复制:从“异步“到“GTID“,数据同步的进化之路
数据库·sql·mysql·oracle·架构·dba·db
看海的四叔9 小时前
【SQL】SQL-管好你的字符串
大数据·数据库·hive·sql·数据分析·字符串
秋99 小时前
TiDB 数据库全链路实战指南:从下载部署到 Java 高并发调优
java·数据库·tidb
zhou周大哥9 小时前
银河麒麟安装mysql
数据库·mysql
无敌的黑星星9 小时前
Spring @Transactional 注解全解析
java·数据库·oracle
Rust研习社9 小时前
Rust + PostgreSQL 极简技术栈应用开发
开发语言·数据库·后端·http·postgresql·rust