数据库范式

一、概念

范式(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班普通班
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值