三大范式和E-R图

一. 范式

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

1. 第一范式

定义

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

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

反例

正例

2. 第二范式

定义

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

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

反例

正例

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

数据冗余

更新异常

插入异常

删除异常

3. 第三范式

定义

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

反例

正例

二. 实体-关系图

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

关系的类型

一对一关系

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

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

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

一对多关系

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

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

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

多对多关系

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

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

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

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

三. 逆向查看EE-R图

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

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

相关推荐
一江寒逸2 小时前
零基础从入门到精通MySQL(上篇):筑基篇——吃透核心概念与基础操作,打通SQL入门第一关
数据库·sql·mysql
@土豆2 小时前
Ubuntu 22.04 运行 Filebeat 7.11.2 崩溃问题分析及解决文档
linux·数据库·ubuntu
专注API从业者2 小时前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫
爱码小白2 小时前
MySQL 单表查询练习题汇总
数据库·python·算法
WangJunXiang62 小时前
第09章:PostgreSQL日常维护
数据库·postgresql
三道渊3 小时前
进程通信与网络协议
开发语言·数据库·php
徒 花3 小时前
数据库知识复习05
android·数据库
豆沙糕3 小时前
RAG文档切分最佳实践:企业级方案+主流策略+生产落地
数据库·人工智能
不会写DN3 小时前
SQL 多表操作全解
数据库·sql