数据库三范式简介

范式的简单介绍:

 

  记得前段时间课程设计,答辩时,老师的第一个问题是:你的数据库表满足第几范式了?我的第一反应是:范式?什么范式?于是老师连看都没看的就把我打发走了。看样子,范式还挺重要的,于是,抱起书本就看,可是,书上有关范式的讲解可能太深奥了,完全不懂,看完只感到头疼,其他什么印象都没有,于是只能百度一下了。

  以下内容是从网上各种搜集,再加上自己的理解,然后总结,整理了之后记录下来,说不定以后会用到。

  

  为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。在关系型数据库中这种规则就称为范式,范式是符合某一种设计要求的总结。要想设计一个结构合理的关系型数据库,必须满足一定的范式;

  目前,主要有六种范式:第一范式、第二范式、第三范式、BC范式、第四范式和第五范式。满足最低要求的叫第一范式,简称1NF。在第一范式基础上进一步满足一些要求的为第二范式,简称2NF,其余依此类推;

  

  在实际开发中最为常见的设计范式是这三个:

  

  1.第一范式

  

  第一范式是最基本的范式,如果数据库表中有主键,并且表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式。

 

     第一范式的合理遵循需要根据系统的实际需求来定。比如某些数据库系统中需要用到“地址”这个属性,本来直接将“地址”属性设计成一个数据库表的字段就行。但是如果系统经常会访问“地址”属性中的“城市”部分,那么就非要将“地址”这个属性重新拆分为省份、城市、详细地址等多个部分进行存储,这样在对地址中某一部分操作的时候将非常方便。这样设计才算满足了数据库的第一范式,如下表所示。

  

用户信息表

编号

姓名

性别

年龄

联系电话

省份

城市

详细地址

1

张红欣

26

0378-23459876

河南

开封

朝阳区新华路23号

2

李四平

32

0751-65432584

广州

广东

白云区天明路148号

3

刘志国

21

0371-87659852

河南

郑州

二七区大学路198号

4

郭小明

27

0371-62556789

河南

郑州

新郑市薛店北街218号

  

上表所示的用户信息遵循了第一范式的要求,这样在对用户使用城市进行分类的时候就非常方便,也提高了数据库的性能。

 

   2.第二范式

 

第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。

选课关系表为SelectCourse(学号, 姓名, 年龄, 课程名称, 成绩, 学分),主键联合主键(学号, 课程名称),因为存在如下决定关系:

(学号, 课程名称) → (姓名, 年龄, 成绩, 学分)

这个数据库表不满足第二范式,因为存在如下决定关系:

(课程名称) → (学分)
(学号) → (姓名, 年龄)


由于不符合2NF,这个选课关系表会存在如下问题:

(1) 数据冗余:

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值