文章目录

  • 一、数据库设计的必要性
  • 二、什么是数据库设计
  • 三、数据库设计的重要性
  • 五、数据模型
    • 5.1 实体-关系(E-R)数据模型
    • 5.2 实体(Entity)
    • 5.3 属性(Attribute)
    • 5.5 关系(Relationship)
  • 六、数据库设计步骤
    • 6.1 需求分析阶段:数据库系统分析
    • 6.2 概要设计阶段:绘制 E-R 图
      • 6.2.1 E-R 图中的实体、属性和关系
      • 6.2.2 映射基数
        • 6.2.2.1 一对一关系
        • 6.2.2.2 一对多关系
        • 6.2.2.3 多对一关系
        • 6.2.2.5 多对多关系
      • 6.2.3 E-R 总结
    • 6.3 详细设计阶段:将 E-R 图转换为表
  • 七、数据库设计规范化
    • 7.1 数据库设计中经常出现的问题
    • 7.2 规范设计
    • 7.3 规范化和性能关系

一、数据库设计的必要性

在实际的软件项目中,如果系统中需要存储的数据量比较大,需要设计的表比较多,表与表之间的关系比较复杂,那我们就需要进行规范的数据库设置。如果不经过数据库的设计,我们构建的数据库不合理、不恰当,那么数据库的维护、运行效率会有很大的问题。这将直接影响到项目的运行性和可靠性。

二、什么是数据库设计

数据库设计是指在建立数据库之前,通过分析和规划,确定数据模型、数据结构、数据表、数据关系、数据约束等一系列数据库的组成要素,以及如何存储、检索和维护数据的方法。

数据库设计实际上就是规划和结构化数据库中的数据对象以及这些数据对象之间的关系过程。

三、数据库设计的重要性

  • 不经过设计的数据库或是设计糟糕的数据库很可能导致

    1. 数据库运行效率地下
    2. 更新、删除、添加数据出现问题
  • 良好设计的数据库

    1. 执行效率高
    2. 使应用程序更便于开发
    3. 扩展性好
    4. 维护性好

数据库设计是建立可靠、高效、易于维护的数据库系统的基础,它可以确保数据一致性,提高数据访问效率。

五、数据模型

数据模型就像是数据间联系的一个轮廓图,整个模型就像一个框架。

如果按照记录间联系的表示方式,对数据模型进行分类,可以分为:层次模型、网状模型、关系模型。前两种又称为格式化数据模型。数据模型的好坏直接影响到数据库的性能,所以数据模型的选择是数据库设计的首要任务。

5.1 实体-关系(E-R)数据模型

E-R数据模型(Entity - Relationship data model),即实体 - 关系数据模型。E-R数据模型不同于传统的关系数据模型,它不是面向实现,而是面向现实物体的。它是最常用的数据建模技术之一,用于设计关系型数据库系统。E-R数据模型是一种图形化方法,是一种用于描述实体、属性和它们之间关系的方法。

5.2 实体(Entity)

数据是用来描述现实中的物体的,而描述的对象都是形形色色的,有具体的、也有抽象的;有物理上存在的、也有概念性的。凡是可以互相区别而且可以被人们认识的事、物、概念等统统抽象为实体。多个相同的类型的实体可以称为实体集(Entity set)。因此,在E-R数据模型中,也有型与值之分;实体可以作为型来定义,每个实体可以是它的实例和值。

5.3 属性(Attribute)

实体一般具体若干特征,这些特征称为实体的属性。而每个属性都有自己的取值范围,在E-R数据模型中称为值集(value set)。在同一实体集中,每个实体的属性及其值集都是相同的,但可能取不同的值。属性对应数据库表的列。

5.5 关系(Relationship)

实体之间会有各种关系,这些关系抽象为联系。不但实体可以有属性,关系也可以有属性。

六、数据库设计步骤

数据库设计可以分为以下几个阶段

  1. 需求分析阶段:分析客户的业务需求,特别是数据方面的需求

  2. 概要设计阶段:绘制数据库的E-R图,并确认需求文档的正确性和完整性,E-R图是项目的设计人员、开发人员、测试人员,以及和客户进行沟通的重要凭据

  3. 详细设计阶段:将概要设计阶段的E-R图转换为数据库表,进行逻辑设计,确定各个表之间的主外键关系,运用数据库的三范式进行审核,并进行技术评审。最后决定选哪种数据库(Oracle、SQLServer、MySQL)来建库、建表。

6.1 需求分析阶段:数据库系统分析

需求分析阶段的重点是调查、收集、分析客户的业务数据需求以及数据的安全性、完整性需求等。

需求分析步骤:

  1. 确认业务需求

  2. 标识关系实体

  3. 标识每个实体的具有的属性

  4. 确认实体之间的关系

6.2 概要设计阶段:绘制 E-R 图

作为数据库设计者,你需要和项目组内其他成员分享你的设计思路,共同研讨数据库设计的合理性、安全性、完整性,并确认是否符合客户的业务需求。那么使用 E-R 图,这种图形化的表示方式最为直观。

6.2.1 E-R 图中的实体、属性和关系

在 E-R 数据模型中,实体被表示为矩形,属性被表示为椭圆形,关系被表示为菱形。实体代表现实世界中的一个对象或概念,属性是实体的特征或属性,而关系是实体之间的连接。

上面的简单 E-R 图可以看出学生和饭卡之间的关系。在上图中可以看出:用矩形表示实体实体是一般名词椭圆表示属性一般也是名词菱形表示关系一般是动词

6.2.2 映射基数

映射基数表示可以通过关系与该实体的个数。对于实体集 A 和 B 之间的二元关系,可能的映射基数有:

6.2.2.1 一对一关系

也就是 A 实体中最多只有一个 B 实体的关联,而 B 实体的最多只有一个 A 实体的关联。用 E-R 图表示:

6.2.2.2 一对多关系

A 实体可以与 B 实体任意数量的进行关联,B 中的实体最多与 A 中的一个实体关联。E-R 图表示:

6.2.2.3 多对一关系

3、 多对一:A 实体最多与一个 B 实体进行关联,而 B 实体可以和任意多个A实体进行关联。E-R 图表示:

6.2.2.5 多对多关系

4、 多对多:A 实体可以有多个 B 实体,而B实体也可以有任意多个 A 实体。E-R 图表示:

6.2.3 E-R 总结

E-R 图可以以图形化的方式将数据库的整个逻辑结构表示出来,组成部分有:

  1. 矩形表示实体集
  2. 椭圆表示属性
  3. 菱形表示关系
  4. 直线用来连接实体集与属性、实体集和关系
  5. 直线、箭头表示实体集之间映射基数

注意在上述关系图中,箭头所指的方向基数为1,也可以都没有箭头,在关系线上用1表示即可

6.3 详细设计阶段:将 E-R 图转换为表

步骤如下:

  1. 将各个实体转换为对应的表,将各属性转换为对应的列
    对于 E-R 图中的每个实体,创建一张对应的表,表名应该与实体名相同或者相似。每个表应该包含与实体相关的所有属性,这些属性应该被转换为表的列。

  2. 标识每张表的主键
    每张表都需要一个主键来唯一标识表中的每一行。通常情况下,实体中的一个属性会被选定为主键。如果没有合适的属性可以用作主键,则可以为表添加一个自增长的整数列作为主键。

  3. 将实体之间的关系转换为表与表之间的主外键关系
    对于 E-R 图中的每个关系,需要将它们转换为表与表之间的主外键关系。每个关系将在其对应的表中生成一个外键列。该列将引用另一个表中的主键列。

更多详细关于 E-R 图的画法以及介绍推荐可以参看:数据库系统设计原理–E-R模型

七、数据库设计规范化

7.1 数据库设计中经常出现的问题

  1. 数据冗余大
  2. 插入数据异常
  3. 删除异常
  4. 更新异常

7.2 规范设计

一个较好的关系数据库模型,它的每个关系中的属性一定要满足某种内在的语义条件,即要按一定的规范设计关系模型,这就是设计的规范化。

在数据库设计时,有一些专门的规则,称为数据库的设计范式,遵循这些规则,就可以创建出良好的数据库,数据库著名的三大范式理论:

  1. 第一范式(1NF)

第一范式是满足关系数据库模型所要遵循的最基本的条件范式,几关系中的每个属性必须是不可再分的简单项,不能是属性组合,即属性的取值是不可拆分的原子值。

  1. 第二范式(2NF)

第二范式是在第一范式的基础上,确保表中的每列都和主键相关。其定义是如果一个关系满足1NF,并且除了主键关系外的其他列都依赖于该主键,则满足第二范式。

  1. 第三范式(3NF)

第三范式是在第二范式的基础上进行的,第三范式的目标是确保每列都和主键列直接相关,而不是间接相关的。其定义是:如果一个关系满足2NF,并且除主键外的其他列都不传递依赖于该主键。

更多关于范式的介绍,请参阅:[ 数据库原理 ] 举例讲解数据库范式(1NF、2NF、3NF、BCNF)与不满足数据库范式的影响

7.3 规范化和性能关系

为了满足三大范式,数据库的性能可能会有一定程度的降低。所以,在实际数据库设计中,我们既要尽量满足三大范式,从而避免数据冗余和各种数据库的操作异常,同时也要考虑数据的访问性能。有时候,为了提高数据库的访问效率,适当的允许少量数据冗余咧存在,才是最适合的数据库设计方案。

【SQL Server】数据库开发指南(一)数据库设计相关推荐

  1. 【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践

    本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中. 本系列文章列表如下: [SQL Server] Linux 运维下对 SQL Server 进行安装.升级.回滚.卸载操作 [ ...

  2. 【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战

    本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中. 本系列文章列表如下: [SQL Server] Linux 运维下对 SQL Server 进行安装.升级.回滚.卸载操作 [ ...

  3. SQL Server 2008高可用性系列:数据库快照

    SQL Server 2008高可用性系列:数据库快照 http://database.51cto.com  2010-09-13 14:45  我爱菊花  博客园  我要评论(0) 摘要:我们今天要 ...

  4. SQL Server 2012中包含的数据库(Contained Database)探索

    SQL Server 2012引入了包含数据库(Contained Database),解决了与当前(非包含)数据库关联的某些问题和复杂性.包含的数据库不依赖于其所属服务器相关的配置.管理.排序规则和 ...

  5. SQL Server 2008 R2如何开启数据库的远程连接

    SQL Server 2008 R2如何开启数据库的远程连接 转载于:https://www.cnblogs.com/macT/p/10213025.html

  6. 从Sql server 2000 到 Oracle 10g数据库迁移数据类型转化

    2010-01-12 从Sql server 2000 到 Oracle 10g数据库迁移数据类型转化 文章分类:数据库 SqlServer 2k转换为Oracle 10g 列名 SqlServer数 ...

  7. php实现sql server数据导入到mysql数据库_php实现SQL Server数据导入Mysql数据库(示例)...

    php将mssql的数据导入到mysql数据库中,代码: 代码示例: //连接SQL server数据库 $conn=mssql_connect("localhost"," ...

  8. SQL Server 2005“备份集中的数据库备份与现有的数据库不同”解决方法此信息转载自BlueSky's Blog,www.heuupk.com,为尊重无价的知识请保留此版权信息。...

    SQL Server 2005"备份集中的数据库备份与现有的数据库不同"解决方法 以前一直使用SQL Server2000,现在使用SQL Server2005,就在现在的项目中使 ...

  9. Sql server 数据转到 Mysql 数据库

    Sql server 数据转到 Mysql 数据库http://www.bieryun.com/3355.html 在网上找了一些方案,目前一个可行的较好的方案,虽然不够完美但也十分好用: 用到的用具 ...

  10. SQL Server 备份与恢复之八:还原数据库

    本文主要来源于Microsoft<SQL Server 2008 R2联机丛书>.转裁请注明出处. 一.还原用户数据库 1."还原数据库"基本操作 (1)目标数据库 在 ...

最新文章

  1. java.lang.RuntimeException: Expected one of local, maven-local, maven-central, scala-tools-releases,
  2. linux下压缩和解压的命令汇总
  3. Exchange ActiveSync
  4. GDT、GDTR、LDT、LDTR的学习
  5. java web从入门到精通视频_JavaWeb从入门到精通(视频实战版)
  6. boost::spirit模块实现使用迭代器位置注释 AST的测试程序
  7. 赠送300家门店260亿销售额的零售企业Power BI实战示例数据
  8. python模拟登录webspare_全面解读python web 程序的9种部署方式
  9. (XGBoost)提升树入门介绍(Inrtoduction to Boosted Trees)
  10. 虚拟计算机用户权限分配,虚拟机实例的权限和安全配置
  11. 确认和回调_右侧突破但是不能追买,等待回调确认,圣诞节附近接回,波段反弹到大寒附近将是一波好收成,但是大寒又是顶部区域需要高抛。...
  12. Atitit 软件项目系统托盘图标解决方案
  13. 《未来编年史》——关于地球未来2000年的预言
  14. JavaSE基础学习
  15. 百度云盘群组中资源文件实时同步更新保存到自己群组的方法
  16. IEEE Xtreme 11.0极限编程题目分类
  17. 基于FPGA的RS232异步串行口IP核设计
  18. 51单片机AD模数转换(SPI通信)
  19. Java项目:图书馆管理系统思路分析
  20. excel数组公式中的意想不到的坑

热门文章

  1. 做双线策略路由用的网通ip段
  2. 奥奇传说系统服务器繁忙,为什么所有的
  3. 个人创业了,做了个网站和App,www.91tianwu.com
  4. 全网最详细用kali linux上的fluxion搭建钓鱼wifi获取wifi密码
  5. 如何在UEFI模式下安装64位win7系统
  6. matlab 作图所用特殊符号及希腊字母总结
  7. 计算机实践教学体系,高校计算机专业软件实践教学体系的建立与实施
  8. 谷歌金山词霸是完全免费的吗?谷歌自己的软件呢?
  9. Python将Word文件中的内容写入Excel文件
  10. 一步步教你画股票图,K线图,高仿雪球股票