日期:2014-05-16 浏览次数:20410 次
为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。在关系型数据库中这种规则就称为范式。范式是符合某一种设计要求的总结。要想设计一个结构合理的关系型数据库,必须满足一定的范式。
在实际开发中最为常见的设计范式有三个:
1 .第一范式
第一范式是最基本的范式。如果数据库表中的所有字段值都是不可分解的原子值,就说明该数据库表满足了第一范式。
第一范式的合理遵循需要根据系统的实际需求来定。比如某些数据库系统中需要用到“地址”这个属性,本来直接将“地址”属 性设计成一个数据库表的字段就行。但是如果系统经常会访问“地址”属性中的“城市”部分,那么就非要将“地址”这个属性重新拆分为省份、城市、详细地址等 多个部分进行存储,这样在对地址中某一部分操作的时候将非常方便。这样设计才算满足了数据库的第一范式,如下表所示。
?
用户信息表
编号 |
姓名 |
性别 |
年龄 |
联系电话 |
省份 |
城市 |
详细地址 |
1 |
张红欣 |
男 |
26 |
0378-23459876 |
河南 |
开封 |
朝阳区新华路23号 |
2 |
李四平 |
女 |
32 |
0751-65432584 |
广州 |
广东 |
白云区天明路148号 |
3 |
刘志国 |
男 |
21 |
0371-87659852 |
河南 |
郑州 |
二七区大学路198号 |
4 |
郭小明 |
女 |
27 |
0371-62556789 |
河南 |
郑州 |
新郑市薛店北街218号 |
上表所示的用户信息遵循了第一范式的要求,这样在对用户使用城市进行分类的时候就非常方便,也提高了数据库的性能。
?
2 .第二范式
第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。
比如要设计一个订单信息表,因为订单中可能会有多种商品,所以要将订单编号和商品编号作为数据库表的联合主键,如下表所示。
?
? 订单信息表
订单编号 |
商品编号 |
商品名称 |
数量 |
单位 |
价格 |
客户 |
所属单位 |
联系方式 |
001 |
1 |
挖掘机 |
1 |
台 |
1200000¥ |
张三 |
上海玖智 |
020-1234567 |
001 |
2 |
冲击钻 |
8 |
把 |
230¥ |
张三 |
上海玖智 |
020-1234567 |
002 |
3 |
铲车 |
2 |
辆 |
980000¥ |
李四 |
北京公司 |
010-1234567 |
?
这样就产生一个问题:这个表中是以订单编号和商品编号作为联合主键。这样在该表中商品名称、单位、商品价格等信息不与该表的主键相关,而仅仅是与商品编号相关。所以在这里违反了第二范式的设计原则。
而如果把这个订单信息表进行拆分,把商品信息分离到另一个表中,把订单项目表也分离到另一个表中,就非常完美了。如下所示。
?
? 订单信息表