实验5.范式
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
为数据库表的联合主键,如下表所示。
订单信息表
订单编号 商品编号 商品名称 数量
单位
商品价格
001
1
挖掘机 1
台
1200000¥
002
2
冲击钻 8
个
230¥
003
3
铲车
2
辆
980000¥
这样就产生一个问题:这个表中是以订单编号和商品编号作为联合主键。这样在该表中商品名 称、单位、商品价格等信息不与该表的主键相关,而仅仅是与商品编号相关。所以在这里违反 了第二范式的设计原则。 而如果把这个订单信息表进行拆分,把商品信息分离到另一个表中,就非常完美了。如下面这 两个所示。
(1) R最高属于第几范式? 说明理由; (2) 请分解R为符合第三范式的关系模式集合,并给出每个关系的主 码: 2、 有关系模式R(U,F),属性集合U ={A,B,C,D,E}, 函数依赖集合F = {A->BC, B->D, CD->E, E->B}, 请回答如下的问题: (1) R的候选码是: (2) R的主码是: (3) R最高属于第几范式? 说明理由; (4) R是否为第三范式 , 解释原因; (5) 请分解R为符合第三范式的关系模式集合,并给出每个关系模式 的主码。 3、 分析如下的问题:有关系模式R(U,F), 属性集U={A,B,C,D,E}, 函数依赖集合F={AB->C, C ->D, D->E },请回答如下的问题:
13285746958
这样在查询订单信息的时候,就可以使用客户编号来引用客户信息表中的记录,也不必在订单 信息表中多次输入客户信息的内容,减小了数据冗余。
实验习题: 1、 有关系模式R(U,F),属性集U={A,B,C,D,E}, 函数依赖集合F={C>A, BC->D, D->E}, 请回答如下的问题:
(1) 第一范式
第一范式是最基本的范式。如果数据库表中的所有字段值都是不可分解的原子值,就说明该数 据库表满足了第一范式。 第一范式的合理遵循需要根据系统的实际需求来定。比如某些数据库系统中需要用到“地址”这 个属性,本来直接将“地址”属性设计成一个数据库表的字段就行。但是如果系统经常会访 问“地址”属性中的“城市”部分,那么就非要将“地址”这个属性重新拆分为省份、城市、详细 地址等多个部分进行存储,这样在对地址中某一部分操作的时候将非常方便。这样设计才算 满足了数据库的第一范式,如下表所示。
实验5 范式
1. 实验目的 (1) 体会关系数据理论,函数依赖以及范式; (2) 体会不好的数据库设计存在的数据冗余,增删改的异常。 2. 实验准备 (1) 掌握建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则---范
式。 (2) 掌握1NF,2NF,3NF思想。 3. 实验内容
要想设计一个结构合理的关系型数据库,必须满足一定的范式。 在实际开发中最为常见的设计范式有三个:
表所示的设计就是一个满足第三范式的数据库表。
订单信息表 订单编号 订单项目 负责人 业务员 订单数量 客户编号
001
挖掘机 刘明
李东明 1台
1
002
冲击钻 李刚
霍新峰 8个
2
003
铲车
郭新一 艾美丽 2辆
1
客户编号
客户名称
客户信息表 所属公司
联系方式
1
李聪
五一建设
13253661015
2
刘新明
个体经营
用户信息表 编号 姓名 性别 年龄 联系电话 省份 城市 详细地址
1 张红欣男 26 0378- 河南 开封 朝阳区新华路23号 23459876
2 李四平女 32 0751- 广州 广东 白云区天明路148
65432584
号
3 刘志国男 21 0371- 河南 郑州 二七区大学路198
87659852
(1) R最高属于第几范式? 说明理由; (2) R属于第三范式?说明理由;
4、某信息一览表如下,其是否满足3NF,若不满足请将其化为符合3NF 的关系。
配件编 配件名 型号规
号
称
格
供应商 名称
供应商地 址
单价
库存量
来自百度文库
5、请确定下列关系的关键字、范式等级;若不属于3NF,则将其化为 3NF 。 例.仓库(仓库号,面积,电话号码,零件号,零件名称,规格,库存 数量)
【手写“回答以下问题”,若空白处不够,请附页完成】
订单编号 001 002 003
订单信息表
商品编号
数量
1
1
2
8
3
2
商品编号
商品信息表
商品名称
单位
商品价格
1
挖掘机
台
1200000¥
2
冲击钻
个
230¥
3
铲车
辆
980000¥
这样设计,在很大程度上减小了数据库的冗余。如果要获取订单的商品信息,使用商品编号到 商品信息表中查询即可。
(3) 第三范式
第三范式在第二范式的基础上更进一层。第三范式需要确保数据表中的每一列数据都和主键直 接相关,而不能间接相关。 比如在设计一个订单数据表的时候,可以将客户编号作为一个外键和订单表建立相应的关系。 而不可以在订单表中添加关于客户其它信息(比如姓名、所属公司等)的字段。如下面这两个
实验名称 实验日期 实验目的
实验环境 实验内容
试验思考
范式
掌握建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规 则---范式。 掌握1NF,2NF,3NF思想。 Windows 7 ,Visio2010 按实验步骤完成范式。 请在这里完成。
回答以下问题:
请简述满足1NF、2NF和3NF的基本条件。
号
4 郭小明女 27 0371- 河南 郑州 新郑市薛店北街
62556789
218号
上表所示的用户信息遵循了第一范式的要求,这样在对用户使用城市进行分类的时候就非常方 便,也提高了数据库的性能。
(2) 第二范式
第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相
关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表 中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。 比如要设计一个订单信息表,因为订单中可能会有多种商品,所以要将订单编号和商品编号作