本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中。
本系列文章列表如下:
【SQL Server】 Linux 运维下对 SQL Server 进行安装、升级、回滚、卸载操作
【SQL Server】数据库开发指南(一)数据库设计的核心概念和基本步骤
【SQL Server】数据库开发指南(二)MSSQL数据库开发对于库、表、数据类型、约束等相关操作
【SQL Server】数据库开发指南(三)面向数据分析的 T-SQL 编程技巧与实践
[ 云原生 | Docker ] 构建高可用性的 SQL Server:Docker 容器下的主从同步实现指南
【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战
【SQL Server】数据库开发指南(六)索引和视图的使用技巧、方法与综合应用
【SQL Server】数据库开发指南(七)MS-SQL存储过程全面解析:种类、优点和创建方法详解
【SQL Server】数据库开发指南(八)高级数据处理技术 MS-SQL 事务、异常和游标的深入研究
【SQL Server】数据库开发指南(九)详细讲解 MS-SQL 触发器的基础概念与应用场景
一、数据库设计的必要性
在实际的软件项目中,如果系统中需要存储的数据量比较大,需要设计的表比较多,表与表之间的关系比较复杂,那我们就需要进行规范的数据库设置。如果不经过数据库的设计,我们构建的数据库不合理、不恰当,那么数据库的维护、运行效率会有很大的问题。这将直接影响到项目的运行性和可靠性。
二、什么是数据库设计
数据库设计是指在建立数据库之前,通过分析和规划,确定数据模型、数据结构、数据表、数据关系、数据约束等一系列数据库的组成要素,以及如何存储、检索和维护数据的方法。
数据库设计实际上就是规划和结构化数据库中的数据对象以及这些数据对象之间的关系过程。
三、数据库设计的重要性
-
不经过设计的数据库或是设计糟糕的数据库很可能导致
- 数据库运行效率地下
- 更新、删除、添加数据出现问题
-
良好设计的数据库
- 执行效率高
- 使应用程序更便于开发
- 扩展性好
- 维护性好
数据库设计是建立可靠、高效、易于维护的数据库系统的基础,它可以确保数据一致性,提高数据访问效率。
五、数据模型
数据模型就像是数据间联系的一个轮廓图,整个模型就像一个框架。
如果按照记录间联系的表示方式,对数据模型进行分类,可以分为:层次模型、网状模型、关系模型。前两种又称为格式化数据模型。数据模型的好坏直接影响到数据库的性能,所以数据模型的选择是数据库设计的首要任务。
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)
实体之间会有各种关系,这些关系抽象为联系。不但实体可以有属性,关系也可以有属性。
六、数据库设计步骤
数据库设计可以分为以下几个阶段
-
需求分析阶段:分析客户的业务需求,特别是数据方面的需求
-
概要设计阶段:绘制数据库的E-R图,并确认需求文档的正确性和完整性,E-R图是项目的设计人员、开发人员、测试人员,以及和客户进行沟通的重要凭据
-
详细设计阶段:将概要设计阶段的E-R图转换为数据库表,进行逻辑设计,确定各个表之间的主外键关系,运用数据库的三范式进行审核,并进行技术评审。最后决定选哪种数据库(Oracle、SQLServer、MySQL)来建库、建表。
6.1 需求分析阶段:数据库系统分析
需求分析阶段的重点是调查、收集、分析客户的业务数据需求以及数据的安全性、完整性需求等。
需求分析步骤:
-
确认业务需求
-
标识关系实体
-
标识每个实体的具有的属性
-
确认实体之间的关系
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,也可以都没有箭头,在关系线上用1表示即可
6.3 详细设计阶段:将 E-R 图转换为表
步骤如下:
-
将各个实体转换为对应的表,将各属性转换为对应的列
对于 E-R 图中的每个实体,创建一张对应的表,表名应该与实体名相同或者相似。每个表应该包含与实体相关的所有属性,这些属性应该被转换为表的列。 -
标识每张表的主键
每张表都需要一个主键来唯一标识表中的每一行。通常情况下,实体中的一个属性会被选定为主键。如果没有合适的属性可以用作主键,则可以为表添加一个自增长的整数列作为主键。 -
将实体之间的关系转换为表与表之间的主外键关系
对于 E-R 图中的每个关系,需要将它们转换为表与表之间的主外键关系。每个关系将在其对应的表中生成一个外键列。该列将引用另一个表中的主键列。
更多详细关于 E-R 图的画法以及介绍推荐可以参看:数据库系统设计原理–E-R模型
七、数据库设计规范化
7.1 数据库设计中经常出现的问题
- 数据冗余大
- 插入数据异常
- 删除异常
- 更新异常
7.2 规范设计
一个较好的关系数据库模型,它的每个关系中的属性一定要满足某种内在的语义条件,即要按一定的规范设计关系模型,这就是设计的规范化。
在数据库设计时,有一些专门的规则,称为数据库的设计范式,遵循这些规则,就可以创建出良好的数据库,数据库著名的三大范式理论:
- 第一范式(1NF)
第一范式是满足关系数据库模型所要遵循的最基本的条件范式,几关系中的每个属性必须是不可再分的简单项,不能是属性组合,即属性的取值是不可拆分的原子值。
- 第二范式(2NF)
第二范式是在第一范式的基础上,确保表中的每列都和主键相关。其定义是如果一个关系满足1NF,并且除了主键关系外的其他列都依赖于该主键,则满足第二范式。
- 第三范式(3NF)
第三范式是在第二范式的基础上进行的,第三范式的目标是确保每列都和主键列直接相关,而不是间接相关的。其定义是:如果一个关系满足2NF,并且除主键外的其他列都不传递依赖于该主键。
更多关于范式的介绍,请参阅:[ 数据库原理 ] 举例讲解数据库范式(1NF、2NF、3NF、B***F)与不满足数据库范式的影响
7.3 规范化和性能关系
为了满足三大范式,数据库的性能可能会有一定程度的降低。所以,在实际数据库设计中,我们既要尽量满足三大范式,从而避免数据冗余和各种数据库的操作异常,同时也要考虑数据的访问性能。有时候,为了提高数据库的访问效率,适当的允许少量数据冗余咧存在,才是最适合的数据库设计方案。