数据库设计

数据库设计

  • 数据库设计定义
    数据库设计 是指对于一个给定的应用环境,构造(设计)优化的数据库逻辑模式和物理结构,并据此建立数据库及其应用系统,使之能够有效的存储和管理数据,满足各种用户的应用需求,包括信息管理要求和数据操作要求。

  • 数据库设计的特点

    • 数据库建设的基本规律
      三分技术,七分管理,十二分基础数据

    • 结构(数据)设计和行为(处理)设计相结合


  • 数据库设计方法
    • 新奥尔良(New Orleans) 方法
      属于规范设计法,思想:过程迭代逐步求精
    • 基于 E-R 模型的数据库设计方法(最常用的方法)
    • 3NF(第三范式)设计方法
    • ODL(Object Definition Language) 面向对象数据库设计方法

  • 数据库设计基本步骤
    • 需求分析
    • 概念结构设计
    • 逻辑结构设计
    • 物理结构设计
    • 数据库实施
    • 数据库运行和维护

需求分析的方法

调查用户需求的具体步骤:

  1. 调查组织机构情况,包括了解该组织的部门组成情况,各部门的职责等,为分析信息流程做准备
  2. 调查各部门的业务活动情况,包括了解各个部门输入和使用什么数据,如何加工处理这些数据,输出什么信息,输出到什么部门,输出结果的格式是什么。这是调查的重点
  3. 再熟悉了业务活动基础上,协助用户明确对新系统的各种要求,包括信息要求,处理要求,安全性与完整性要求
  4. 确定新系统的边界,对前面调查的结果进行初步分析,确定哪些功能由计算机完成或将来准备让计算机完成,哪些活动由人工完成,由计算机完成的功能就是新系统应该实现的功能。

常用的调查方法:

  1. 跟班作业,通过亲身参加业务工作来了解业务活动情况
  2. 开调查会。通过与用户座谈来了解业务活动情况及用户需求
  3. 请专人调查
  4. 询问,对某些调查中的问题,可以找专人询问
  5. 设计调查表请用户填写。如果调查表设计的合理,这种方法是很有效的
  6. 查阅记录,查阅与原系统有关的数据记录

数据字典

数据字典:系统中各类数据描述的集合。进行详细的数据收集和数据分析所获得的主要成果

  1. 数据项
    不可分的数据单位
    数据项描述 = |数据项名,数据项含义说明,别名,数据类型,长度,取值范围,取值含义,与其他数据项的逻辑关系,数据项之间的联系|
  1. 数据结构
    数据结构反应了数据之间的组合关系,一个数据结构可以由若干个数据项组成,也可以由若干个数据结构组成,或由若干个数据结构混合组成,对数据结构的描述通常包含以下内容:
    数据结构描述 = |数据结构名,含义说明,组成:|数据项或数据结构||

  2. 数据流
    数据流是数据结构在系统内传输的路径。对数据流的描述通常包括下面的内容
    数据流描述 = |数据流名,说明,数据流来源,数据流去向,组成:|数据结构|,平均流量,高峰期流量|

  3. 数据存储
    数据存储描述 = |数据存储名,说明,编号,输入的数据流,输出的数据流,责成|数据结构|,数据量,存取频度,存取方式|

  4. 处理过程
    处理过程描述 = |处理过程名,说明,输入:|数据流|,输入:|数据流|,处理:|简要说明||

    数据字典是关于数据库中数据的描述,即元数据,而不是数据本身


概念结构设计

将需求分析得到的用户需求抽象为信息结构即概念模型的过程就是概念结构设计

  • 概念结构
    特点如下:

    1. 能真实、充分地反映现实世界,包括事物和事物之间的联系,能满足用户对数据的处理要求,是对现实世界的一个真实模型
    2. 易于理解,从而可以用它和不熟悉计算机的用户交换意见,用户的积极参与是数据库设计成功的关键
    3. 易于更改,当应用环境和应用要求更改时,容易对概念模型修改和扩充
    4. 易于向关系、网状、层次等各种数据模型转换。

    概念模型的工具是 E-R 模型


概念结构设计的方法与步骤

  • 自顶向下,首先定义全局概念结构的框架,然后逐步细化
  • 自底向上,首先定义各个局部应用的概念结构,然后将他们集成起来,得到全局概念结构。
  • 逐步扩展。首先定义最重要的核心概念结构,然后向外扩充,以滚雪球的方式逐步生成其他概念结构,直至总体概念结构
  • 混合策略。即将自顶下下和自底向上相结合,用自顶向下策略设计一个全局概念结构的框架,以它为骨架集成自底向上策略中设计的各局部概念结构

经常采用的策略是自底向上的方法,即自顶向下的锦讯需求分析,然后再自底向上的设计概念结构

需求分析--> 分 E-R 图--> 总 E-R 图


数据抽象与局部视图设计

三种抽象

  • 分类 (Classification)
  • 聚集 (Aggregation)
  • 概括 (Generalization)

E-R 图调整:
为了简化 E-R 图的处置,现实世界的事物能作为属性对待的,尽量作为属性对待。

属性:

  • 作为属性,不能再具有需要描述的性质。属性必须是不可分割的数据项,不能包含其他属性
  • 属性不能与其他实体具有联系,即 E-R 图中所表示的联系是实体之间的联系

根据需求分析结果 画出第一层数据流图,第二层数据流图等

分别设计它们的 分 E-R 图 再汇总成 局部应用的 分 E-R 图


视图的集成

将所有的分 E-R 图综合成一个系统的总 E-R 图。

  • 两种集成方式

    • 多个分 E-R 图一次集成
    • 逐步集成,用累加的方式一次集成两个分 E-R 图
  • 集成过程

    • 合并,解决各分 E-R 图之间的冲突,将各分 E-R 图合并起来生成初步 E-R 图
    • 修改和重构。消除不必要的冗余,生成基本 E-R 图
  • 合并分 E-R 图,生成初步 E-R 图

    1. 属性冲突
      属性域冲突,即属性值得类型、取值范围或取值集合不同、例如零件号,有的部门把它定义为整数,有的部门把它定义为字符型。不同的部门对零件号和编码也不同。又如年龄,某些部门以出生年月日期形式表示职工的年龄,而另一些部门用整数表示职工的年龄。
      属性取值单位冲突,例如,零件的重量有的以公斤为单位,有的以斤为单位,有的以克为单位。

    属性冲突需要各部门讨论协商,解决起来并非易事

    1. 命名冲突
      同名异议,不同意义的对象在不同的局部应用中具有相同的名字
      异名同义(一义多名),即同一意义的对象在不同的局部应用中具有不同的名字。如对科研项目,财务科称为项目,科研处称为课题,生产管理处称为工程

    处理命名冲突通常也像处理属性冲突一样,通过讨论,协商等行政手段加以解决

    1. 结构冲突
      同一对象在不同应用中具有不同的抽象,例如,职工在某一局部应用中被当做实体,而在另一局部应用中则被当做属性

    解决办法,通常是把属性变换为实体 或 把实体变换为属性,使同一对象具有相同的抽象。

同一实体在不同分 E-R 图中所包含的属性个数和属性排列次序不完全相同。

解决办法,使该实体的属性取各分 E-R 图中属性的并集,再适当调整属性的次序

  • 消除不必要的冗余,设计基本 E-R 图

逻辑结构设计

逻辑结构设计步骤

  • 将概念结构转换为一般关系、网状、层次模型
  • 将转换来的关系、网状、层次模型向指定

DBMS 支持下的数据模型转换。

  • 对数据模型进行优化

  • E-R 图向关系模型的转换
    一个实体型转换为一个关系模式,实体的属性就是关系的属性,实体的码就是关系的码

对于实体型间的联系则有一下不同的情况:

  1. 一个 1:1 联系可以转换为一个独立的关系模式,也可以与任意一端对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,每个实体的码均是该关系的候选码。如果与某一端实体对应的关系模式合并,则需要在该关系模式的属性中加入另一个关系模式的码和联系本身的属性。

  2. 一个 1:n 联系可以转换为一个独立的关系模式,也可以与 n 端 对应的关系模式合并。如果转换为一个独立的关系模式,则与该联系相连的各实体的码以及联系本身的属性均转化为关系的属性,而关系的码为 n 端实体的码

  3. 一个 m:n 联系转换为一个关系模式。与该联系相连的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系码的一部分

  4. 3 个或 3 个以上实体间的一个多元联系可以转换为一个关系模式。与该多元联系相连的各实体的码以及联系本身的属性均转换为关系的属性,各实体的码组成关系的码或关系吗的一部分

  5. 具有相同码的关系模式可以合并

  • 数据模型的优化

    1. 确定数据依赖,按需求分析阶段所得到的语义,分别写出每个关系模式内部各属性之间的数据依赖以及不同关系模式属性之间的数据依赖。

    2.对于各个关系模式之间的数据依赖进行极小化处理,消除冗余的联系

    1. 按照数据依赖的理论对关系模式逐一进行分析,考察是否存在部分函数依赖、传递函数依赖、多值依赖等,确定各关系模式分别属于第几范式

    2. 按照需求分析阶段得到的处理要求,分析对于这样的应用环境这些模式是否合适,确定是否要对某些模式进行合并或分解

    3. 对关系模式进行必要的分解,提高数据操作的效率和存储空间的利用率。常用的两种分解方法是水平分解和垂直分解。

      水平分解是把(基本)关系的元祖分成若干子集合,定义每个子集合为一个子关系,以提高系统的效率。根据“80/20”原则,一个大关系中,经常被使用的数据只是关系的一部分,约20%,可以把经常使用的数据分解出来,形成一个子关心。如果关系 R 上 具有 n 个事物,而且多数事物存取的数据不想交,则 R 可以分解为少于或等于 n 个子关系, 使每个事物存取的数据对应一个关系

      垂直分解就是把关系模式 R 的属性分解为若干子集合,形成若干子关系模式。垂直分解的原则是,经常在一起使用的属性从 R 中 分解出来形成一个子关系模式。垂直分解可以提高某些事物的效率,但也可以使另一些事务不得不执行链接操作,从而降低了效率。因此是否进行垂直分解取决于分解后 R 上的所有事务的总效率是否得到了提高。垂直分解需要确保无损链接性和保持函数依赖,即保证分解后的关系具有无损连接性和保持函数依赖性。

  • 设计用户子模式 (view 视图模式)

    1. 使用更符合用户习惯的别名

    2. 可以对不同级别的用户定义不同的 View,以保证系统的安全性

    3. 简化用户对系统的使用


数据库的物理设计

数据库物理设计通常分为两步:

  1. 确定数据库的物理结构,在关系数据库中主要指存取方法和存储结构

  2. 对物理结构进行评价,评价的终点是时间和空间效率

  • 数据库物理设计的内容和方法
    查询:

    • 查询的关系
    • 查询条件所设计的属性
    • 链接条件所涉及的属性
      - 查询的投影属性

    更新:

    • 被更新的关系
    • 每个关系上的更新操作条件所涉及的属性
    • 修改操作要改变的属性值

内容:

  • 为关系模式选择存取方法

  • 设计关系、索引等数据库文件的物理存储结构

  • 关系模式存取方法选择
    存取方法是快读存取数据库中的数据,常用的有三类

  • 索引存取方法
    根据应用要求确定对关系的哪些属性列建立索引、哪些属性列建立组合索引、哪些索引要设计为唯一索引等

    1. 如果一个(或一组)属性经常在查询条件中出现,则考虑在这个(或这组)属性上建立索引(或组合索引)
    2. 如果一个属性经常违最大值和最小值等聚集函数的参数,则考虑在这个属性上建立索引。
    3. 如果一个(或一组)属性经常在链接操作的链接条件中出现,则考虑在这个(或这组)属性上建立索引
  • 聚簇存取方法
    为了提高某个属性(或属性组)的查询素的,把这个或这些属性(称为聚簇码)上具有相同值得元祖集中存放在连续的物理块称为聚簇

    1. 经常在一起进行连接操作的关系可以建立聚簇
    2. 如果一个关系的一组属性经常出现在相等比较条件中,则该单个关系可建立聚簇
    3. 如果一个关系的一个(或一组)属性上的值重复率很高,则此单个关系可建立聚簇。
  • HASH 存取方法的选择
    如果一个关系的属性主要出现在等值链接条件中或主要出现在相等比较选择条件中,而且满足下列两个条件之一,则此关系可以选择 HASH 存取方法。
    1. 如果一个关系的大小可以预知,而且不变
    2. 如果关系的大小动态改变,而且数据库管理系统提供了动态 HASH 存取方法
  • 确定数据库的存储结构
    确定数据库物理结构主要指确定数据的存放位置和存储结构,包括:确定关系、索引、聚簇、日志、备份等存储安排和存储结构,确定系统配置等

    1. 确定数量的存放位置
    2. 确定系统配置
  • 评价物理结构
    对时间效率、空间效率、维护代价和各种用户要求进行权衡。


数据库的实施和维护

  • 数据的载入和应用程序的调试
    先载入少量数据调试,运行合格后,再大批输入数据,逐步增加数据量。。。

  • 数据库调试试运行
    首先调试运行DBMS 的恢复功能。

  • 数据库的运行和维护
    下面都是 DBA 的职责

    • 数据看的转储 和 恢复
    • 数据库的安全性、完全性控制
    • 数据库性能的监督、分析和改造
    • 数据库的重组织与重构造
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容