- 第一范式(1NF):每一个属性都是原子项,不可分割
INF中所述的不可分割,是指在可分割的情况下必须分割,这是在应用环境中来判断的,当属性是文档时,虽然文档有段落标记,但还是不应该分割。
- 第二范式:每个非主属性要完全函数依赖于候选键,或者是主键。
关键词是“完全依赖”,与“部分依赖”或“局部依赖”相对,如果候选键或主键由两个属性组成,非主属性不能只依赖与其中一个或部分属性。
比如:股票日行情表由股票代码、股票名称、日期、收盘价四个属性组成,这就违反了2NF,因为“股票名称”部分依赖于“股票代码”。
- 第三范式:所有非主属性对任何候选关键字都不存在传递依赖
关键词是“传递依赖”,如果非主属性通过另一个非主属性依赖主键,则是传递依赖。
比如:股票基本信息表由股票代码、股票名称、企业名称、所在地区、所在省份组成,其中“所在省份”依赖于所在地区,存在传递依赖。
---------------------------------------------
几个相关术语:
- 超键(super key):在关系中能唯一标识元组的属性集称为关系模式的超键
- 候选键(candidate key):不含有多余属性的超键称为候选键
- 主键(primary key):用户选作元组标识的一个候选键称为主键
- 主属性(Prime Attribute):候选键中的属性称为主属性
- 非主属性(Non-Key Attribute):不包含在任何候选键中的属性称为非主属性。
本文详细解释了数据库设计中的三个规范化形式:第一范式(1NF)、第二范式(2NF)和第三范式(3NF)。重点介绍了每个范式的定义、特征及如何避免常见的设计缺陷,如部分依赖和传递依赖。

被折叠的 条评论
为什么被折叠?



