数据库范式

一、概念

范式(NF NormalForm)就是指需要遵循的设计规则;
范式越高,设计质量越高,但难度越大,通常我们讲三范式,实际不止三种;
在这里插入图片描述

二、三范式

2.1、一范式

原则:列不可分(原子性)
举例:下面表一中的家庭地址列通常是可以继续拆分,这样更便于地址的分层管理(当然也不排除有此类细节)

用户名家庭地址
张三广东省广州市xxx区xxx街道xxx号
用户名省份城市详细地址
张三广东省广州市xxx区xxx街道xxx号

2.2、二范式

原则:表不可分,一张表只存一种类型数据(不建议多对多关系数据混合)
举例:下例中将学生信息课程信息混在一张表中,一个学生可以选择多门课程,一门课程也可以对应多个学生,这样不太合理,实际应该拆分为学生表课程表关系表3张,来实现学生与课程的多对多关系;

学号姓名课程编号课程名称
1张三1语文
2李四1语文
1张三2数学
2王五2数学
4赵六1语文

2.3、三范式

原则:表不可分,(不建议一对多关系数据混合)
举例:下例中将学生信息班级信息混在一张表中,一个学生只能一个班级,一个班级有多个学生,这样也不太合理,实际可以拆成学生表班级表2张,通过班级编号作为外键关联,不用过多数据冗余;

学号姓名班级编号班级名称班级名称
1张三1A班普通班
2李四1A班普通班
3王五2B班重点班
4赵六1A班普通班
©️2020 CSDN 皮肤主题: Age of Ai 设计师:meimeiellie 返回首页