实用数据库设计

数据库设计的三个阶段


概念设计

将需求分析数据抽象成局部E-R模型,再将局部E-R模型集成为全局E-R模型
E-R图主要是由实体、属性和关系三个要素构成的。在ER图中,使用了下面几种基本的图形符号:

  • 实体,矩形
  • 属性,椭圆形
  • 关系,菱形


    ER图示例
实体关联关系有三种:
  • 1对1(1:1)
  • 1对多(1:N)
  • 多对多(M:N)
逻辑设计

是对概念数据模型进一步的分解和细化,将概念模型转换成特定DBMS所支持的数据模型的过程 。由初始关系模式设计到关系模式规范化再到模式评价

  • 确定物理结构:存取方法和存储结构
  • 评价物理结构:评价重点是时间和空间效率
数据库设计三范式:
  • 第一范式
    1、每一列属性都是不可再分的属性值,确保每一列的原子性
    2、两列的属性相近或相似或一样,尽量合并属性一样的列,确保不产生冗余数据。
  • 第二范式
    1、每一行的数据只能与其中一列相关,即一行数据只做一件事。只要数据列中出现数据重复,就要把表拆分开来
  • 第三范式
    1、数据不能存在传递关系,即没个属性都跟主键有直接关系而不是间接关系。像:a-->b-->c 属性之间含有这样的关系,是不符合第三范式的。
逻辑模型示例
物理结构设计

物理数据库设计的主要目标就是描述如何物理的实现逻辑数据库的设计。对于关系模型,物理数据库设计活动包括:

  • 根据逻辑数据模型,物理的创建关系表和完整性约束。
  • 确定数据的存储结构和访问方式,确保数据库系统的性能最优。
  • 设计安全保护机制。
    物理模型是对真实数据库的描述。数据库中的一些对象如下:表,视图,字段,数据类型、长度、主键、外键、索引、是否可为空,默认值。
    物理结构示例

概念模型、逻辑模型、物理模型的区别

对象 概念模型 逻辑模型 物理模型
实体 实体 实体
属性 属性 属性 字段
关系 1:1 1:n n:1 关系 外键
关系 1:n n:1 实体 表(关系表)
关系 n:m 实体 表(关系表)

附:使用PowerDesigner设计数据库

使用PowerDesigner设计数据库er图
https://blog.csdn.net/angel_g/article/details/62418890
使用PowerDesigner设计数据库逻辑模型
https://jingyan.baidu.com/article/4b07be3cb2804148b380f317.html
使用PowerDesigner设计数据库物理模型
http://m5.baidu.com/sf_edu_wenku/view/2176a6d1bb68a98270fefa63
使用PowerDesigner转换er到物理模型
https://www.cnblogs.com/brolanda/p/4265806.html

你可能感兴趣的:(实用数据库设计)