数据库建模

        数据库建模:也就是建 “ER” 表,就是实体联系表。

        实体一般是名称  英文翻译:entity

    用“方框” 表示:实体;

    用“椭圆” 表示:属性;

    用“菱形” 表示:关系;

 

        要满足的条件:

   满足三大范式:

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

 

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


  用户信息表 


编号 姓名 性别 年龄 联系电话 
省份 
城市 详细地址 
张红欣 男 26 0378-23459876 河南 开封 朝阳区新华路23号 

李四平 女 32 0751-65432584 广州 广东 白云区天明路148号 

刘志国 男 21 0371-87659852 河南 郑州 二七区大学路198号

郭小明 女 27 0371-62556789 河南 郑州 新郑市薛店北街218号 

 


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


2.第二范式 


第二范式在第一范式的基础之上更进一层。第二范式需要确保数据库表中的每一列都和主键相关,而不能只与主键的某一部分相关(主要针对联合主键而言)。也就是说在一个数据库表中,一个表中只能保存一种数据,不可以把多种数据保存在同一张数据库表中。 
比如要设计一个订单信息表,因为订单中可能会有多种商品,所以要将订单编号和商品编号作为数据库表的联合主键,如下表所示。   
 订单信息表 

 

 


订单编号 商品编号 商品名称 数量 单位 商品价格 

001 挖掘机 台 1200000¥

002 冲击钻 个 230¥ 

003 铲车 辆   980000¥ 


这样就产生一个问题:这个表中是以订单编号和商品编号作为联合主键。这样在该表中商品名称、单位、商品价格等信息不与该表的主键相关,而仅仅是与商品编号相关。所以在这里违反了第二范式的设计原则。 
而如果把这个订单信息表进行拆分,把商品信息分离到另一个表中,就非常完美了。如下面这两个所示。   
 订单信息表 
订单编号 商品编号 数量

001            

002           

003           
  商品信息表 
商品编号 商品名称 单位 商品价格

       挖掘机    台    1200000¥

       冲击钻    个    230¥

       铲车      辆    980000¥ 
这样设计,在很大程度上减小了数据库的冗余。如果要获取订单的商品信息,使用商品编号到商品信息表中查询即可。   


3.第三范式 
第三范式在第二范式的基础上更进一层。第三范式需要确保数据表中的每一列数据都和主键直接相关,而不能间接相关。 


比如在设计一个订单数据表的时候,可以将客户编号作为一个外键和订单表建立相应的关系。而不可以在订单表中添加关于客户其它信息(比如姓名、所属公司等)的字段。如下面这两个表所示的设计就是一个满足第三范式的数据库表。   
订单信息表 
订单编号 订单项目 负责人 业务员 订单数量 客户编号 

001 挖掘机 刘明 李东明 1台 

002 冲击钻 李刚 霍新峰 8个 

003 铲车 郭新一 艾美丽 2辆 
  客户信息表 
客户编号  客户名称  所属公司   联系方式 

        李聪    五一建设   13253661015

        刘新明 个体经营    13285746958 
这样在查询订单信息的时候,就可以使用客户编号来引用客户信息表中的记录,也不必在订单信息表中多次输入客户信息的内容,减小了数据冗余。

 

总结 :第一范式:行不可重复,列不可再分  

       第二范式:非主键列 必须依赖主键列

       第三范式:非主键之间必须相互独立

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值