数据库设计概念_第1页
数据库设计概念_第2页
数据库设计概念_第3页
数据库设计概念_第4页
数据库设计概念_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数据库设计概念在设计数据库时,需要计划要存储有关哪些事物的信息,以及要保存有关各个事物的哪些信息。您还需要确定这些事物的相互关系。如果使用数据库设计中的术语,在这一步创建的数据库原型就称作概念数据库模型。实体和关系要存储其相关信息的可识别对象或事物称作实体。它们之间的关联称作关系。在数据库描述语言中,可以将实体看做名词,将关系看做动词。由于概念模型对实体和关系进行了明确的区分,因此这种模型非常有用。这种模型将在任何特定数据库管理系统中实施设计所涉及的细节隐藏起来,从而使设计者可以集中考虑基础数据库结构。因此,这种模型也成为了一种用于讨论数据库设计的通用语言。实体关系图概念数据库模型主要由一个显

2、示实体和关系的示意图构成。这个示意图通常称作实体关系图。因此,许多人也使用实体关系建模这个词来指创建概念数据库模型的任务。概念数据库设计是一个由上至下的设计方法。现在有许多功能完备的工具可以帮助您按照这种方法或其他方法进行设计,例如,SybasePowerDesigner。虽然本章的目的只是进行介绍,但也提供了足够的信息可以帮助您设计简单的数据库。实体在数据库中,一个实体对应于一个名词。可识别的对象,例如,雇员、订单项、部门和产品,都是实体的示例。在数据库中用表代表各个实体。置入数据库的实体都源于要使用数据库执行的活动,例如,跟踪销售电话和维护雇员信息,等等。属性每个实体都包含一些属性。属性是

3、指要为事物存储的特定特性。例如,在雇员实体中,需要存储雇员ID号、姓氏和名字、地址,以及与一个特定雇员相关的其他信息。属性也称作特性。实体用一个矩形框表示。在矩形框内部,列出与该实体相关联的属性。Emplo/eeFirstNftiqL押Address标识符是指所有其他属性都依赖的一个或多个属性。它在实体中唯一地标识一个项目。在要组成标识符的属性名下面加上下划线。在上面的Employee实体中,EmployeeNumber唯一地标识一个雇员。所有其他属性都存储只与那个雇员相关的信息。例如,一个雇员编号唯一地确定一个雇员的名字和地址。两个雇员可能具有相同的名字或相同的地址,但可以确保他们的雇员编号

4、不同。EmployeeNumber下面带有下划线,表示它是标识符。为每个实体都创建一个标识符是一个良好的习惯。这些标识符在表中将成为主键,下文中将对此进行说明。主键值必须唯一,并且不能为空或未定义。主键唯一地标识表中的每一行,并且提高数据库服务器的性能。关系在数据库中,实体之间的一个关系对应于一个动词。一个雇员属于一个部门,或者一个办事处位于一座城市。数据库中的关系可能表现为表间的外键关系,也可能自身就成为独立的表。您将在本章中看到这两种情况的示例。数据库中的关系就是控制实体中数据的规则或惯例的编码。如果每个部门有一个部门经理,可以在部门和雇员之间建立一对一的关系来标识该部门经理。当关系置入数

5、据库结构后,就不可能再出现例外。没有地方可以输入另一个部门经理。复制部门条目将复制部门ID,而它是标识符。标识符不允许有重复。提示严格的数据库结构有很大好处,因为它可以消除不一致的问题,例如一个部门有两个经理。另一方面,作为设计者,您应该使设计具有足够的灵活性以便于进行扩展,以满足某些未预见到的需要。对设计合理的数据库进行扩展通常并不很困难,但修改现有表结构可能会致使整个数据库及其客户端应用程序无法使用。关系的基数表之间有三种关系。这三种关系对应于关系中所涉及的实体的基数(数量)。一对一关系关系通过在两个实体间画一条连线表示。连线上可以有其他标记,例如,下图中所示的两个圆圈。这些标记的用途将在

6、下文中进行说明。在下图中,一个部门由一DepartinentEmployee个雇员管理。一对多关系如果实体1中包含的一项可以与实体2中的多项相关联,这样一种关系用多条连线连接到实体2来表示。在下图中,一个办事处可以有多部电话。OfficeTelephones-o电话位肯关系多对多关系在这种情况下,两个实体的连接处都要画多条连线。这表示一个仓库可以存放许多不同的部件,而同一类部件也可以存放在许多仓库中。角色您可以用两个角色来描述每种关系。角色是用于从每个观察点描述关系的动词或短语。例如,雇员和部门之间的关系可以用以下两个角色来描述:雇员属于部门。而部门包含雇员。角色非常重要,因为它们为您提供了一

7、种方便且有效的方法来验证您的工作。提示不管是从左到右读取还是从右到左读取,下面的规则都会使读取这些图示变得容易:读取(1)第一个实体的名称,(2)第一个实体旁边的角色,(3)到第二个实体的连接的基数,(4)第二个实体的名称。强制元素表示关系的连线末端的小圆圈具有非常重要的作用。圆圈表示存在于该实体内的元素在另一个实体内不必有对应的元素。如果出现的是一段交叉线而不是圆圈,则表示另一个实体中的每个元素在该实体中至少应有一个对应元素。下面举例说明这些标记的含义。此图具有以下四个含义:一家出版社出版了零或多本书。一本书由恰好一家出版社出版。一本书由一或多位作者撰写。一位作者撰写了零或多本书。提示可以把

8、小圆圈看做数字0,把交叉线看做数字1。圆圈表示至少零。交叉线表示至少一。反身关系有时,同一个实体内的条目之间也存在关系。这种关系称作反身关系。关系的两端都连接到同一个实体。此图具有以下两个含义。一个雇员最多只向另外一个雇员报告。一个雇员管理零个或多个雇员。请注意,在这个关系中,关系在两个方向上都应该是可选的。某些雇员不是经理。同样,至少应该有一个雇员是公司的总经理,因此不向任何人报告。自然,还应指定一个雇员不能是他自己的经理。这个限制是一种业务规则。业务规则将在下文中作为设计过程的一部分进行讨论。将多对多关系更改为实体如果有属性与关系相关联,而不是与实体相关联,则可以将该关系更改为实体。有时,

9、多对多关系可能会出现这种情况。有些属性特定于关系,因此将其添加到任何一个实体中都不合理。假设部件存放在多个不同的仓库中。而您画的设计图如下所示。但您希望记录各个部件在各个地点的存货数量。该属性只能与关系相关联。每个数量都依赖于所涉及的部件和仓库。要表示这样一种情况,可以按以下方式重画设计图:请注意以下细节的变化:两个新关系将关系实体分别与原有的两个实体连接起来。这两个关系的名称继承自原有关系的两个角色:分别为存放在和包含Inventory实体中的每个条目要求Parts实体中有一个强制条目,Warehouse实体中有一个强制条目。这些关系都是强制的,因为仓储关系只在与一个特定部件和一个特定仓库相

10、关联时才有意义。新实体既依赖于Parts实体,也依赖于Warehouse实体,表示新实体由这两个实体的标识符共同标识。在这个新设计图中,Parts实体中的一个标识符和Warehouse实体中的一个标识符唯一地标识Inventory实体中的一个条目。圆圈和多线条之间的三角形将两个新关系连接到新的Inventory实体,并表示依赖性。不要在Inventory实体中添加PartNumber或WarehouseID特性。Inventory实体中的每个条目都依赖于一个特定部件和一个特定仓库,但这些三角形可以更清晰的表示这种依赖性。设计过程设计过程包含五个主要步骤。第1步:确定实体和关系第2步:确定所需数

11、据第3步:规范化数据第4步:解析关系第5步:验证设计有关实现数据库设计的详细信息,请参见使用数据库对象第1步:确定实体和关系实体和关系示例第2步:确定所需数据第3步:规范化数据第4步:解析关系第5步:验证设计第1步:确定实体和关系确定设计中的实体及实体之间的关系:1.确定高级别的活动确定要使用该数据库执行的一般活动。例如,可能要用它来跟踪有关雇员的信息。确定实体对于这些活动,确定需要维护有关哪些类对象的信息。这些对象将成为实体。例如,聘用雇员,将雇员分配到某个部门,并确定其技能级别。确定关系对这些活动进行分析,然后确定实体间会有哪些关系。例如,部件和仓库之间有关系。定义两个角色来描述每个关系。

12、分解活动开始时确定了高级别的活动。现在,需要进一步分析这些活动,确定是否可以将其中一些分解为较低级别的活动。例如,象维护雇员信息这样一个高级别活动可以分解为:o添加新雇员。o更改现有雇员信息。o删除已离职的雇员。确定业务规则对业务说明进行分析,确定应遵守哪些规则。例如,一个部门有且仅有一个经理就可以作为一个业务规则。这些规则将被置入数据库的结构中。实体和关系示例示例ACMECorporation是一家小公司,它在五个地点设有办事处。目前,ACME有75名雇员。该公司正准备迅速发展,并且已经确定了九个部门,每个部门都有自己的部门经理。为帮助公司招聘新雇员,人事部门确定了68项技能,并且认为公司将

13、来需要具有这些技能的雇员。聘用了一个雇员后,将对该雇员在每项技能上的专业级别进行评定。确定高级别的活动ACMECorporation需要考虑的高级别活动有:聘用雇员。解聘雇员。维护雇员的个人信息。维护有关公司所需技能的信息。维护有关哪个雇员具有哪项技能的信息。维护有关部门的信息。维护有关办事处的信息。确定实体和关系确定实体(对象)和连接实体的关系(角色)。根据以上说明和高级别的活动创建一个设计图。用矩形框表示实体,用连线表示关系。用两个角色标记每个关系。还应使用适当的标注表示那些一对多、一对一和多对多关系。下面是一个粗略的实体关系图。在本章后面的部分将逐渐对其进行改进。分解高级别的活动根据上述

14、高级别的活动可以确定以下较低级别的活动:添加或删除雇员。添加或删除办事处。列出某个部门的雇员。在技能列表中添加技能。确定某个雇员的技能。确定某个雇员在各项技能上的技能级别。确定在某项技能上具有相同技能级别的所有雇员。更改雇员的技能级别。使用这些较低级别的活动可以确定是否需要新表或新关系。确定业务规则业务规则通常可以表示为一对多、一对一和多对多关系。可能相关的业务规则有以下几个:现在有五个办事处;扩展计划允许增加到最多十个。雇员可以更换部门或办事处。每个部门有一个部门经理。每个办事处最多有三个电话号码。每个电话号码有一个或多个分机。聘用了一个雇员后,将对该雇员在各项技能上的专业级别进行评定。每个

15、雇员具有三到二十项技能。可以将雇员分配到一个办事处,也可以不分配第2步:确定所需数据确定所需数据:确定支持数据。2.列出所有需要跟踪的数据。为每个实体设置数据。列出每个实体的可用数据。描述实体(对象)的数据可以回答涉及何人、何事、何处、何时以及何故的问题。列出每个关系(动词)需要的所有数据。列出适用于每个关系的数据(如果有)。确定支持数据您所确定的支持数据将成为实体中属性的名称。例如,以下数据可能适用于Employee实体、Skill实体,和ExpertIn实体。雇员技能擅长于雇员ID技能ID技能级别雇员的名字技能名称掌握该项技能的日期雇员的姓氏技能说明雇员的部门雇员所在的办事处雇员的地址根据

16、这些数据创建的设计图将如下图所示:请注意,列出的所有属性并未都在这张设计图中出现。未出现的属性可归为以下两类:有一些属性隐式包含在其他关系中;例如,雇员的部门和雇员所在的办事处分别用连接Department和Office实体的关系表示。其他一些属性未出现的原因是它们与这些实体并不相关联,而是与这些实体间的关系相关联。上图并不完整。在绘制完整的实体关系图时,第一类属性会自然出现。可以通过将多对多关系转换为实体来添加第二类属性。新实体同时依赖于Employee实体和Skill实体。它将借用这些实体中的标识符,因为它同时依赖于这两个实体。注意确定支持数据时,一定要参考前面确定的活动以了解将如何访问这

17、些数据。例如,在某些情况下可能需要按雇员的名字列出雇员,而在另一些情况下可能需要按姓氏列出。要满足这两种需要,应创建一个FirstName属性和一个LastName属性,而不应创建一个既包含名字又包含姓氏的属性。将姓氏和名字分开后,以后可以创建两个索引,分别适用于这两项任务。请选择一致的名称。使用一致的名称可以使数据库便于维护,并且便于阅读报告和输出窗口。例如,如果一个属性使用了缩略名称,如Emp_status,贝V另一个属性不应使用完整名称,如Employee。应使名称保持一致,如Emp_status和Emp_ID。在这个阶段,数据是否与正确的实体相关联并不十分重要。您可以根据自己的判断进行

18、设计。在下一节中,将对设计进行测试,检查您的判断是否正确。第3步:规范化数据规范化是指一系列测试,通过这些测试可以消除冗余的数据,并确保数据与正确的实体或关系相关联。共有五项测试。本节介绍其中前三项测试。这三项测试最重要,因此也最常使用。为什么要进行规范化?规范化的目的是消除冗余并提高一致性。例如,如果在多个位置都存储了客户的地址,在这些客户搬家后将很难正确更新所有副本。有关规范化测试的更多信息,请参见有关数据库设计的书籍。范式数据规范化包括几项测试。数据在通过了第一项测试后,我们认为它满足第一范式;通过了第二项测试后,它满足第二范式;通过了第三项测试后,贝满足第三范式。规范化数据库中的数据:

19、1.列出这些数据。o为每个实体至少确定一个键。每个实体必须有一个标识符。o确定关系的键。关系的键是该关系所连接的两个实体的键。o检查支持数据列表中是否有计算数据。计算数据通常不存储在关系数据库中。2.2.第一范式测试。o如果一个属性在同一个条目上可以有几个不同的值,则删除这些重复的值。o用删除的数据创建一个或多个实体或关系。3.4.第二范式测试。3.4.o找出带有多个键的实体和关系。o删除只依赖于键的一部分的数据。o用删除的数据创建一个或多个实体或关系。第三范式测试。o删除依赖于实体或关系中的其他数据,而不依赖于键的数据。用删除的数据创建一个或多个实体或关系。数据和标识符开始进行规范化(对设计

20、进行测试)之前,简单地列出数据,并为每个表确定一个唯一的标识符。标识符可以由一个数据(属性)或几个数据(复合标识符)组成。标识符是唯一地标识实体中各行的一组属性。例如,Employee实体的标识符是EmployeeID。WorksIn关系的标识符由OfficeCode和EmployeeID属性组成。数据库中每个关系的标识符可由该关系所连接的各个实体的标识符组成。在下表中,带有星号的属性为该实体或关系的标识符。实体或关系属性办事处*办事处代码办事处地址电话号码工作地点为办事处代码雇员ID部门*工作地点为办事处代码雇员ID部门*部门ID部门名称经理为部门ID雇员ID2.2.2.2.属于属于部门ID

21、*雇员ID技能*技能ID技能名称技能说明擅长于*技能ID*雇员ID技能级别掌握日期雇员*雇员ID姓氏名字社保号码地址电话号码出生日期第一范式测试进行第一范式测试时,应找出可能有重复值的属性。如果有多个值都适用于某一项,则删除这些属性。将这些重复属性移到一个新实体中。在下面的实体中,Phonenumber可能会重复一一个办事处可以有多个电话号码。DepartmentEmployef删除重复的属性,并创建一个名为Telephone的新实体。在Office与Telephone之间建立一个关系。第二范式测试删除不依赖于整个键的值。只需要检查标识符由多个属性组成的实体和关系。进行第二范式测试时,应删除所

22、有不依赖于整个标识符的数据。每个属性都应依赖于组成标识符的所有属性。在这个示例中,EmployeeandDepartment实体的标识符由两个属性组成。有些数据与这两个标识符属性并不都具有依赖关系,例如,部门名称只依赖于其中一个属性,DepartmentID,而雇员的名字只依赖于EmployeeID。EmployeeandDepartmentEmplDUEEIDD皀pmrtmm仃tIDEmployeefirtEmployeeI目stnDup曰rtmuntname将其他雇员数据不依赖的标识符DepartmentID移到其名为Department的实体中。还应移动所有依赖于它的属性。在Employ

23、ee和Department之间创建一个关系。第三范式测试删除不直接依赖于键的数据。进行第三范式测试时,应删除所有依赖于其他属性而不直接依赖于标识符的属性。在这个示例中,EmployeeandOffice实体中有一些属性依赖于其标识符EmployeeID。但是,Officelocation和Officephone等属性却依赖于另一个属性,Officecode。这些属性不依赖于标识符EmployeeID。删除Officecode和那些依赖于它的属性。创建另一个名为Office的实体。然后,创建一个连接Employee和Office实体的关系。第4步:解析关系执行完规范化过程后,设计几乎就完成了。唯

24、一还需要做的事情就是生成与概念数据模型相对应的物理数据模型。这个过程也称作解析关系,因为其中涉及的大量工作就是将概念模型中的关系转换为相应的表和外键关系。虽然概念模型在很大程度上独立于实施细节,但物理数据模型与特定数据库应用程序中的表结构和可用选项紧密相关。在这里,我们所指的应用程序就是AdaptiveServerAnywhere。解析不带有数据的关系要实施不带有数据的关系,需要定义外键。外键是指包含另一个表中的主键值的一列或几列。利用外键一次可以访问多个表中的数据。使用象SybasePowerDesigner的DataArchitect组件的数据库设计工具可以自动生成物理数据模型。但如果要自

25、己生成物理模型,有一些基本规则可以帮助您确定将哪些列设置为键。一对多一个一对多关系总是会变为一个实体和一个外键关系。请注意,实体将变为表。实体中的标识符(至少一部分)将变为表中的主键。属性将变为列。在一对多关系中,一方的实体中的标识符成为多方的表中新加的外键列。在这个示例中,Employee实体变为Employee表。同样,Department实体变为Department表oEmployee表中将出现一个名为DepartmentID的外键。一对一对于一对一关系,可在其中任意一个表中设置外键。如果关系在一侧是强制的,但在另一侧是可选的,应在可选的一侧设置外键。在这个示例中,在Truck表中设置外

26、键(VehicleID)是因为车辆不一定都是卡车。因此,上面的实体关系模型将解析为下面的数据库基本结构。多对多在多对多关系中,创建的新表中有两个外键。必须这样安排才会使数据库更高效。新的StorageLocation表将Parts和Warehouse表关联起来。解析带有数据的关系有些关系可能会带有数据。这种情况常常会在多对多关系中出现。在这种情况下,每个实体都将解析为一个表。每个角色将变为指向另一个表的外键。Inventory实体借用Parts和Warehouse表中的标识符,因为它与这两个表都有依赖关系。经过解析后,这些借用的标识符将成为Inventory表的主键。第5步:验证设计实施设计之

27、前,需要确保该设计能够满足您的需要。检查在设计过程之初确定的活动,确保可以访问这些活动所需要的数据。能否找到一条获取所需信息的途径?设计是否满足您的需求?能否获得所需要的全部数据?如果您对上述所有问题的回答都是肯定的,那么就可以实现您的设计了。最终设计按照第1步到第3步为前面提到的小公司设计数据库,将得到以下实体关系图。这个数据库现在处于第三范式。学握于1SkillIDNimtierSkillnwm已Skilldescription1管理DepsrtmentDEgrtrriEntID_Departmentname有OfficeIDMumlJEFOfficenameAddress管理DepsrtmentDEgrtrriEntID_Departmentname有OfficeIDMumlJEFOfficenameAddressEmploy亡亡EtTiployeeIDFirstnameLstnameHomeaddress隶雇于管理包含设计数据库表属性数据库设计将确定需要哪些表,以及每

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论