在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

时间:2020-12-14 06:46:36

SQL Server中实现关系模型的阶梯到级别3t -SQL DML

格雷戈里·拉森(Gregory Larsen),2017/08/02(第一次出版:2011 /11/09)

原文链接:http://www.sqlservercentral.com/articles/Stairway+Series/75775/

该系列

本文是系列的一部分:T-SQL的进阶

这个进阶将为您提供一个基本的理解,即如何使用SQL Server的transact - SQL(t - SQL)方言对SQL Server表中的数据进行处理。DML是数据操纵语言,是处理数据的语言的方面。它包括语句选择、插入、更新和删除。这个楼梯也将提供一些SQL语言的历史和一些关于集合理论的一般概念。每个级别都将建立在之前的级别上,因此,当您完成这些工作时,您将很好地理解如何从SQL Server中选择和修改数据。

在这个楼梯的前一级,我提供了关于SQL的基本选择语句和历史的信息。这些级别为您提供了理解如何检索数据以及SQL环境如何随着技术和技术解决方案发生变化而变化的基础。在这个级别,我将探索如何实现基于关系模型的简单SQL Server数据库。在开始创建数据库之前,首先让我介绍一下关系模型的创建者的一些历史。

关系数据建模之父

关系数据库设计的概念最初是由Edgar f . Codd在1970年提出的,论文标题为“大型共享数据银行的数据关系模型”。Codd在IBM工作时开发了这种建模理论。IBM在Codd的数据建模概念上跳得不够快,因此并不是第一个供应关系数据库引擎的供应商,它利用了Codd的新关系数据建模理论。Codd的关系建模概念现在是用来在SQL Server和其他关系数据库引擎中创建关系数据库的框架。

Codd出生于英格兰的波特兰岛,在加入皇家空军之前学习了数学和化学,成为了第二次世界大战的飞行员。1948年,他搬到纽约,开始在IBM工作,在那里他是一名数学程序员。他漂流了好几年,最终搬到加州,在IBM圣何塞研究实验室工作。直到20世纪90年代,当他的健康状况不佳迫使他退休时,Codd继续努力完善并证明了关系数据模型的合理性。 Edgar F. Codd 于2003年4月18日去世,享年79岁。

SQL Server中实现关系模型

这个楼梯不是用来教你关系数据建模,或数据库设计,而是教你如何从一个关系模型创建一个SQL Server数据库。但是在我为创建SQL Server数据库提供代码块之前,我们首先需要探索一个将被实现的关系数据模型。我的简单模型将包含一些实体(数据表),其中有主键定义和不同实体之间的一些关系(外键约束)。

我的简单的关系模型将是一个简单的酒店预订系统。这个预订系统需要跟踪客户预订信息。图1说明了这个简单的关系模型,我将使用t - sql实现它:

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

图1:一个简单的关系数据库模型,由6个表组成

通过回顾这个模型,您可以看到它包含许多实体(由方框表示)来跟踪预订相关信息。每个实体都由一些属性(列)组成,其中一个或多个属性被标识为主键(粗体和下划线的名称)。也表示实体之间的一些关系(以箭头表示),以显示不同的实体之间是如何相互关联的。我将使用实体、属性、主键和关系的模型,然后开发一个物理SQL Server数据库,它表示此关系模型的设计。

要从这个模型构建物理数据库,我们需要在SQL Server中识别基于此模型定义的不同对象。对于图1中的每个实体或框,我将在SQL Server中创建一个表。对于每个实体的每个属性,我将在关联的表中创建一个列。对于每个主键,我将创建一个唯一的集群索引(注意,使用唯一的非聚集索引也可以创建主键)。更多信息索引参考索引在http://www.sqlservercentral.com/stairway/72399/上楼梯)。最后,对于每个关系,我将创建一个外键约束。

要开始构建我的数据库,我首先需要创建一个SQL Server数据库来保存我计划创建的所有新数据库对象。我的数据库将被称为房间预订。我将使用以下的t - sql代码创建我的数据库:

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

要从我的模型中开始构建我的房间预订数据库对象,我将创建表对象。要在SQL服务器中创建表,我需要使用create table语句。使用CREATE TABLE语句,我将能够定义每个表和每个表中的所有列。下面是创建SQL Server表的简单语法:

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

地点:

<table_name> =表名

<column_definition> = column_name data_type[NULL | NOT NULL]

对于CREATE TABLE语句的完整语法,请参见联机的SQL Server Books。

我创建的第一个表将是Customer表,它是使用清单1中的代码创建的。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单1:创建Customer表

在这段代码中,当我创建我的Customer表时,我创建了我需要的所有列,但我还指定了在插入或更新记录时,该列是否需要一个值。我通过在某些列上指定NOT NULL来实现这一点,而其他列则指定为NULL。

如果一个列被定义为不为空,那意味着你不能创建一个记录,除非你用一个实际值填充这个列。而使用NULL规范定义一个列意味着您可以创建一行,而不必为这个列指定一个值,或者另一种方法是,该列允许空值。在上面的CREATE TABLE语句中,我允许columns Address2和EmailAddress支持NULLs,而其余的列都需要在创建行时提供一个值。

这个CREATE TABLE语句并没有完全定义我的Customer表,因为它在上面的关系数据库模型中表示。我仍然需要在列CustomerID上创建一个主键约束。这个主键约束将确保该表中没有两个记录具有相同的CustomerID值。创建主键的代码如清单2所示。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单2:向Customer表添加主键约束

这个ALTER TABLE语句为我的Customer表添加了一个主键约束。主键将以集群索引PK_Customer的形式创建。

在transact - sql语言中,通常有不止一种方法可以做同样的事情。或者,通过运行清单3中的CREATE table语句,我可以一次性创建客户表和主键。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单3:用主键创建Customer表的另一种方法

在这一点上,我已经向您展示了如何创建带有定义主键的表。剩下要展示的是如何创建外键约束。但在此之前,先让我先给您提供一个脚本,以在上面的关系数据库模型中创建其余的表和主键。您可以在清单4中找到它。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单4:创建额外的表和主键约束

一个外键约束在两个相互关联的表之间强制引用完整性。外键约束定义的表是“引用表”,需要在另一个表中有相关的记录,称为“引用”表,任何时候在表中插入或更新一行。在图1的关系模型中,这些外键关系由箭头表示。外键约束只在关系中的一个表上定义。在我的图表中,外键约束将定义在具有箭头尾部(无尖端)的那些表上。

为了在关系模型中定义这些外键约束,我需要修改每个引用表来添加约束。清单5是我可以用来在保留表上创建外键约束的t - sql代码。这个约束确保记录不会被插入或更新到预订表中,除非在Customer表中基于CustomerId找到匹配的记录。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单5:在引用Customer表的预订表上创建一个外键约束

为了完成我的设计,我需要实现图1中模型中所标识的所有其他外键constUNK。清单6包含ALTER TABLE语句,用以在我的数据模型中创建额外的外键约束。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单6:创建额外的外键限制

验证数据库设计

一旦我完成了从数据模型构建数据库的工作,我应该验证所实现的设计,以确保它是正确的。这个验证过程是确保我在物理数据库中构建的所有数据完整性规则都正确地实现了。在我的设计中,我需要验证这些规则

﹒所有插入或更新的行必须对定义为NOT NULL的列有一个特定的值。

﹒主键的列不允许重复的值

﹒具有外键const晕倒的列不允许在引用表中没有匹配记录的数据

在验证数据完整性规则之前,我首先需要用一些有效数据填充引用的表。我将使用清单7中的代码来填充那些有一些有效数据的表:

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单7:插入初始数据

为了验证我在数据库中构建的数据完整性规则,我将运行清单8中的INSERT语句。

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

清单8:用INSERT语句测试各种约束

这些INSERT语句中的每一个都应该失败,因为它们违反了构建在RoomReservation数据库中的数据完整性规则。第一个INSERT语句违反了预订规则列的非空验证检查。

第二个INSERT语句违反了放在RoomType表上的主键约束。这个INSERT语句试图为RoomTypeID列插入3的值。问题是在RoomType值为3的RoomType表中已经有了记录。

最后一个INSERT语句违反了CustomerPaymentType表的外键约束。在这个特殊的INSERT语句中,Customer表中没有CustomerID值为2的值。

要正确地插入这些记录,插入的数据值需要清理。一旦数据被清理干净,我就可以将这些新数据插入到合适的表中。清单9包含清除所有数据完整性检查并成功插入到房间预订数据库中的适当表的清理INSERT语句:

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML

关系数据库设计

我的预订示例演示了如何使用关系模型并使用它来实现SQL Server数据库。通过使用非NULL、主键和外键constUNK,我将数据完整性规则构建到数据库设计中。这允许我在底层数据库定义中执行这些规则,而不必在业务处理层中编写代码来验证这些数据规则。通过这样做,我允许SQL Server数据库引擎为我执行这些数据完整性检查。

通过了解并在关系数据库模型周围创建数据库设计,您将构建一个健壮且高效的数据库实现,您可以在数据库中构建数据完整性检查。

这篇文章是t - sql DML进阶的一部分

注册到我们的RSS频道,一旦我们在阶梯上发布一个新的级别,就会得到通知!

 

在SQL Server中实现关系模型的阶梯到级别3的t -SQL DML