SQL数据库设计(一)---需求分析与逻辑设计

今天先来介绍 数据库设计中的需求分析和逻辑设计(ER图)阶段,明天介绍物理设计与维护优化,数据库设计是非常有意思的:-)

数据库设计

根据系统业务的需要,结合我们所选用的DBMS,为这个业务系统构建出最优的数据存储模型。
并建立好数据库中的表结构,以及表与表之间的关联关系的过程.使之能有效的对应用系统中的数据进行存储,
并可以高效的对已经存储的数据进行访问.

优良的数据库设计
  • 减少数据冗余
  • 避免数据维护异常
  • 节约存储空间
  • 高效的访问

需求分析

分析数据和属性各自的特点

  1. 了解系统中所要存储的数据
  2. 了解数据的存储特点
  3. 了解数据的存储周期

需求分析中需要了解的问题

  1. 实体之间的关系
  2. 实体包含的属性是什么
  3. 那些属性或属性的组合可以唯一标示一个实体

电商网站数据模块的分解

模块属性可选唯一标识属性存储特点
用户模块用户名,密码,电话,邮箱,身份证号,地址,姓名等用户名,身份证号,电话随上线时间增加,需要永久存储
商品模块商品编码,商品名称,商品描述,商品品类,供应商名称,重量,有效期,价格等(商品名称,供应商名称),商品编码对于下线商品可以归档存储
订单模块订单号,用户姓名,用户电话,收货地址,商品编号,商品名称,数量,价格,订单状态,支付状态,订单类型订单号永久存储(分表,分库存储)
购物车模块用户名,商品编号,商品名称,商品和价格,商品描述,商品分类,加入时间,商品数量(用户名,商品编号,加入时间),购物车编号不用永久存储(设置归档,清理规则)
供应商模块供应商编号,供应商名称,联系人,电话营业执照号,地址,法人供应商编号,营业执照号永久存储

逻辑设计

ER图:逻辑模型得到展示方式
使用ER图对数据库进行逻辑建模,与DBMS无关。

ER图的图形含义

这里写图片描述

电商网站数据模块ER图

这里写图片描述

逻辑设计名词解释

这里写图片描述
不满足三个范式的设计的数据库会出现操作异常及数据冗余
操作异常
这里写图片描述
数据冗余:相同的数据在多个地方得到,或者说表中的某个列可以由其他列计算得到。

第一范式(1NF)

数据库表中所有字段都是单一属性的,不可再分的,这些单一属性使用基本的数据结构构成的.
第一范式要求数据库中所有的表都是二维表.

第二范式(2NF)

数据库中的表不存在非关键字段对任意候选关键的字段的部分函数依赖.
部分函数依赖指存在组合关键字中某一关键字决定非关键字的情况.
所有单关键字段的表都符合第二范式

不满足第二范式的示例
这里写图片描述

解决不满足第二范式造成的操作异常问题

这里写图片描述

第三范式(3NF)

第三范式是建立在第二范式的基础上的
如果数据库表不存在非关键字段对任意候选关键字段的传递函数依赖则符合第三范式

不满足第三范式的示例
这里写图片描述
解决不满足第三范式造成的操作异常
这里写图片描述

BC范式(BCNF)

在第三范式的基础上,数据库表中如果不存在任何字段对任意候选关键字段的传递函数依赖则符合BC范式
如果是复合关键字,则复合关键字之间也不能存在函数依赖关系.

这里写图片描述

参考资料
http://www.2cto.com/database/201409/331105.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值