【SQL Server】数据库开发指南(一)数据库设计的核心概念和基本步骤

本系列博文还在更新中,收录在专栏:#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 触发器的基础概念与应用场景

一、数据库设计的必要性

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

二、什么是数据库设计

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

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

三、数据库设计的重要性

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

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

image

上面的简单 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 图表示:

image

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 规范化和性能关系

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

  • 36
    点赞
  • 70
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 57
    评论
作为一个SQL Server数据库开发人员,我的主要职责是设计开发和维护数据库系统。以下是我在这个角色中需要掌握的技能和职责: 1. 数据库设计:我需要了解数据库设计原则和范式,以便在设计数据库时遵循最佳实践。我需要使用ER建模工具进行实体关系图设计,以确保数据完整性和一致性。我还需要考虑数据存储和检索的最佳方法,以确保数据库的高效性和可伸缩性。 2. SQL编程:我需要精通SQL语言,以便编写高效、可读性强的查询和存储过程。我需要了解T-SQL基本语法和功能,以便能够进行数据操作,如插入、更新和删除数据。我还需要了解如何使用索引和视图来提高查询性能。 3. 数据库维护和性能优化:我需要定期备份和还原数据库,以确保数据的安全性和可恢复性。我需要监视数据库性能指标,如CPU利用率、磁盘IO和内存使用情况,以便及时识别和解决性能问题。我需要了解如何进行索引、查询、存储过程和视图的优化,以提高数据库性能。 4. 数据库安全:我需要了解如何配置数据库安全性,以保护敏感数据免受未经授权的访问或恶意攻击。我需要了解如何创建和管理用户、角色和权限,以确保数据的机密性和完整性。 5. 数据库迁移和集成:我需要了解如何迁移和集成不同的数据库系统,以满足不同组织的需求。我需要了解如何使用ETL工具和数据集成技术来实现数据交换和数据共享。 总之,作为SQL Server数据库开发人员,我需要不断学习和更新自己的技能和知识,以适应不断变化的数据库技术和需求。我需要与其他开发人员、管理员和业务用户紧密合作,以确保数据库系统的高效性、可靠性和安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bluetata

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值