数据库设计--冗余的一点建议

首先,声明的一点:不合理的设计不要说冗余设计,那只是借口,真正的冗余设计不是这样的。

冗余设计的原则:

1、尽量减少冗余

2、只对关键数据冗余

3、冗余必须是证据,要保证数据出错时,冗余要正确

4、如果必要,库中数据与冗余数据要来源不一致


正确认识冗余:

主键与外键在多表中的重复出现, 不属于数据冗余,这个概念必须清楚,事实上有许多人还不清楚。非键字段的重复出现, 才是数据冗余!而且是一种低级冗余,即重复性的冗余。高级冗余不是字段的重复出现,而是字段的派生出现。

〖例〗:商品中的“单价、数量、金额”三个字段,“金额”就是由“单价”乘以“数量”派生出来的,它就是冗余,而且是一种高级冗余。冗余的目的是为了提高处理速度。只有低级冗余才会增加数据的不一致性,因为同一数据,可能从不同时间、地点、角色上多次录入。因此,我们提倡高级冗余(派生性冗余),反对低级冗余(重复性冗余)。


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数据库设计的基本步骤 (1)需求分析阶段:需求收集和分析,得到数据字典和数据流图。 (2)概念结构设计阶段:对用户需求综合、归纳与抽象,形成概念模型,用 E-R 图表示。 (3)逻辑结构设计阶段:将概念结构转换为某个 DBMS 所支持的数据模型。 (4)数据库物理设计阶段:为逻辑数据模型选取一个最适合应用环境的物理结构。 (5)数据库实施阶段:建立数据库,编制与调试应用程序,组织数据入库,程序试运行。 (6)数据库运行和维护阶段:对数据库系统进行评价、调整与修改。 1 数据库设计概述 数据库设计是指对于一个给定的应用环境,构造最优的数据库模式,建立数据库及其应用系统,使之能够有效地存储数据。 数据库设计的基本步骤: 需求分析 概念结构设计 逻辑结构设计 物理结构设计 数据库的建立和测试 数据库运行和维护。 数据库各阶段设计描述 2 概念结构设计 在早期的数据库设计,在需求分析阶段后,就直接进行逻辑结构设计。由于此时既要考虑现实世界信息的联系与特征,又要满 足特定的数据库系统的约束要求,因而 对于客观世界的描述受到一定的限制。同时,由于设计时要同时考虑多方面的问题,也使设计 工作变得十分复杂。1976 年 P.P.S.Chen 提出在逻辑结构 设计之前先设计一个概念模型,并提出了数据库设计的实体--联系方法 (Entity--Relationship Approach)。这种方法不包括深的理论,但提供了一个简便、有效的方法,目前成为数据库设计中通用的工具。 有许多商业软件支持 E-R 模型,如 Sybase 公司的 PowerDesigner DataArchitect(最新版本 v9.5.1 for Windows)、微软公司 Microsoft InfoModeler (VisioModeler)等。 图 S-designer DataArchitect 5.1 设计的 E-R 模型 使用 E-R 模型来进行概念模型的设计通常分两步进行, 首先是建立局部概念模型, 然后综合局部概念模型, 成为全局概念模型。 2.1 E-R 模型基本符号 实体的表示:用长方形 联系的表示:用菱形,1:1、1:n (m:1)、(m:n) 属性的表示:用椭圆形 E-R 图具有以下几个特性: 一个联系集合可以定义在两个或两个以上的实体集合上,例如老师--学生--课程的联系集合 S-T-C,就是定义在三个实体上。 一个联系集合也可以定义在一个实体集合上,例如零件下又分有子零件,每个零件又可由 m 个子零件组成,每个子零件又可组 合成 n 个零件。 对于给定的实体集合,可以定义一个以上的联系集合,例如工程项目--工人可以定义两个联系集合,其中一个表示工程项目和 工人的联系,另一个表示工程项目和工人中的工程项目负责人的联系。前者是 n:m 的联系,后者是 1:1 的联系。 实体联系图可以表示一个实体类型对另一个实体类型的存在的依赖性,例如工人这一实体下反映其被抚养者的关系,就是依赖 关系,这种联系用箭头表示,说明抚养者这个实体的存在取决于工人中的相应的那个实体。 2.2 初步 E-R 图设计 在数据分析的基础上,就可以着手设计概念结构。设计初步 E-R 图的步骤: 先设计局部 E-R 图,也称用户视图 综合各局部 E-R 图,形成总的 E-R 图,即用户视图的集成。 在设计初步 E-R 图时,要尽量能充分地把组织中各部门对信息的要求集中起来,而不需要考虑数据的冗余问题。 局部概念模型设计是从用户的观点出发, 设计符合用户需求的概念结构。 局部概念模型设计的就是组织、 分类收集到的数据项, 确定哪些数据项作为实体,哪些数据项作为属性,哪些数据项是同一实体的属性等。确定实体与属性的原则: 能作为属性的尽量作为属性而不要划为实体; 作为属性的数据元素与所描述的实体之间的联系只能是 1:n 的联系; 作为属性的数据项不能再用其他属性加以描述,也不能与其他实体或属性发生联系。 例 1:一个机械制造厂的简单管理系统。首先按工厂技术部门和工厂供应部门设计两个局部 E-R 图。工厂技术部门关心的是产品的性 能参数,及由哪些零件组成,零件的材料和耗用量等;工厂供应部门关心的是产品的价格,使用材料的价格及库存量等。 例 1 图 局部 E-R 图 综合这两个分 E-R 图,得到初步 E-R 图。 例 1 图 初步 E-R 图 初步 E-R 图是现实世界的纯粹表示, 可能存在冗余的数据和实体间冗余的联系。 所谓冗余的数据是指可由基本数据导出的数据, 冗余的联系是指可由基本联系导出的联系。 2.3 基本 E-R 图设计 初步 E-R 图由于存在冗余的信息,会破坏数据库的完整性,给数据库的管理带来麻烦,以至引起数据不一致的错误。因此,必 须消除数据上的冗余和联系上的冗余,消除冗余

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值