1、1PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:概念数据模型概述 第 1 页: 概念数据模型概述 第 2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数据项、新增数据项、数据项的唯一性. 第 6 页: 联系的定义及使用 【IT168 技术文档】目标: 本小节主要介绍 PowerDesigner 中概念数据模型 CDM 的基本概念。一、概念数据模型概述 数据模型是现实世界中数据特征的抽象。数据模型应该满足三个方面的要求: 1)能够比较真
2、实地模拟现实世界 2)容易为人所理解 3)便于计算机实现 概念数据模型也称信息模型,它以实体联系(Entity-RelationShip,简称E-R)理论为基础,并对这一理论进行了扩充。它从用户的观点出发对信息进行建模,主要用于数据库的概念级设计。 通常人们先将现实世界抽象为概念世界,然后再将概念世界转为机器世界。换句话说,就是先将现实世界中的客观对象抽象为实体(Entity)和联系 (Relationship),它并不依赖于具体的计算机系统或某个 DBMS 系统,这种模型就是我们所说的 CDM;然后再将 CDM 转换为计算机上某个 DBMS 所支持的数据模型,这样的模型就是物理数据模型,即
3、PDM。 CDM 是一组严格定义的模型元素的集合,这些模型元素精确地描述了系统的静态特性、动态特性以及完整性约束条件等,其中包括了数据结构、数据操作和完整性约束三部分。 1)数据结构表达为实体和属性; 2)数据操作表达为实体中的记录的插入、删除、修改、查询等操作; 3)完整性约束表达为数据的自身完整性约束(如数据类型、检查、规则等)和数据间的参照完整性约束(如联系、继承联系等); 二、实体、属性及标识符的定义 实体(Entity),也称为实例,对应现实世界中可区别于其他对象的“事件”或“事物”。例如,学校中的每个学生,医院中的每个手术。 2每个实体都有用来描述实体特征的一组性质,称之为属性,一
4、个实体由若干个属性来描述。如学生实体可由学号、姓名、性别、出生年月、所在系别、入学年份等属性组成。 实体集(Entity Set)是具体相同类型及相同性质实体的集合。例如学校所有学生的集合可定义为“学生”实体集,“学生”实体集中的每个实体均具有学号、姓名、性别、出生年月、所在系别、入学年份等性质。 实体类型(Entity Type)是实体集中每个实体所具有的共同性质的集合,例如“患者”实体类型为:患者门诊号,姓名,性别,年龄,身份证号.。实体是实体类型的一个实例,在含义明确的情况下,实体、实体类型通常互换使用。 实体类型中的每个实体包含唯一标识它的一个或一组属性,这些属性称为实体类型的标识符(
5、Identifier),如“学号”是学生实体类型的标识符,“姓名”、“出生日期”、“信址”共同组成“公民”实体类型的标识符。 有些实体类型可以有几组属性充当标识符,选定其中一组属性作为实体类型的主标识符,其他的作为次标识符。 三、实体、属性及标识符的表达 3PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:PowerDesigner 概念数据模型 第 1 页: 概念数据模型概述 第 2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数据项、
6、新增数据项、数据项的唯一性. 第 6 页: 联系的定义及使用 本小节主要介绍 PowerDesigner 概念数据模型以及实体、属性创建。一、新建概念数据模型1)选择 FileNew,弹出如图所示对话框,选择 CDM 模型(即概念数据模型)建立模型。2)完成概念数据模型的创建。以下图示,对当前的工作空间进行简单介绍。(以后再更详细说明)43) 选择新增的 CDM 模型,右击,在弹出的菜单中选择“Properties”属性项,弹出如图所示对话框。在“General”标签里可以输入所建模型的名 称、代码、描述、创建者、版本以及默认的图表等等信息。在“Notes”标签里可以输入相关描述及说明信息。当
7、然再有更多的标签,可以点击 “More“按钮,这里就不再进行详细解释。5二、创建新实体1)在 CDM 的图形窗口中,单击工具选项版上的 Entity 工具,再单击图形窗口的空白处,在单击的位置就出现一个实体符号。点击 Pointer 工具或右击鼠标,释放 Entitiy 工具。如图所示2)双击刚创建的实体符号,打开下列图标窗口,在此窗口“General”标签中可以输入实体的名称、代码、描述等信息。6三、添加实体属性1)在上述窗口的“Attribute”选项标签上可以添加属性,如下图所示。7注意:数据项中的“添加属性”和“重用已有数据项”这两项功能与模型中 Data Item 的 Unique
8、code 和 Allow reuse 选项有关。P 列表示该属性是否为主标识符;D 列表示该属性是否在图形窗口中显示;M 列表示该属性是否为强制的,即该列是否为空值。如果一个实体属性为强制的,那么, 这个属性在每条记录中都必须被赋值,不能为空。2)在上图所示窗口中,点击插入属性按钮,弹出属性对话框,如下图所示。注意:这里涉及到域的概念,即一种标准的数据结构,它可应用至数据项或实体的属性上。在以下的教程中将另立章节详细说明。8PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:属性的标准检查约束 第 1 页: 概念数据模型概述 第
9、2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数据项、新增数据项、数据项的唯一性. 第 6 页: 联系的定义及使用 目标:本小节主要介绍属性的标准检查约束、如何定义属性的附加检查。一、定义属性的标准检查约束标准检查约束是一组确保属性有效的表达式。在实体属性的特性窗口,打开如图所示的检查选项卡。在这个选项卡可以定义属性的标准检查约束,窗口中每项的参数的含义,如下参数 说明Minimum 属性可接受的最小数Maximum 属性可接受的最大数Default 属性不赋值时,系统提供的默认值Unit 单位,如公
10、里、吨、元9Format 属性的数据显示格式Lowercase 属性的赋值全部变为小写字母Uppercase 属性的赋值全部变为大写字母Cannot modify 该属性一旦赋值不能再修改List Of Values 属性赋值列表,除列表中的值,不能有其他的值Label 属性列表值的标签二、定义属性的附加检查当 Standard checks 或 Rules 不能满足检查的要求时,可以在 Additional Checks 选项卡的Server 子页上,通过 SQL 语句中使用%MINMAX%、%LISTVAL%、%RULES%、%UPPER%、%LOWER% 几个变量来定义 Standard
11、 和 Rule,如图所示%MINMAX%、%LISTVAL%、%UPPER%、%LOWER%在 Standard Check 中定义的 Minimum 和 Maximum、List values 、uppervalues、lowervalues%RULES%在 Rules 特性窗口 Expression 选项卡中定义的有效性规则表达式10PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:如何定义实体的主、次标识符 第 1 页: 概念数据模型概述 第 2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约
12、束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数据项、新增数据项、数据项的唯一性. 第 6 页: 联系的定义及使用 目标:本小节主要介绍如何定义实体的主、次标识符。一、标识符标识符是实体中一个或多个属性的集合,可用来唯一标识实体中的一个实例。要强调的是,CDM 中的标识符等价于 PDM 中的主键或候选键。每个实体都必须至少有一个标识符。如果实体只有一个标识符,则它为实体的主标识符。如果实体有多个标识符,则其中一个被指定为主标识符,其余的标识符就是次标识符了。二、如果定义主、次标识符1)选择某个实体双击弹出实体的属性对话框。在 Identifiers 选项卡上可以进行实体标识符的定
13、义。如下图所示112)选择第一行“主标识符”,点击属性按钮或双击第一行“主标识符”,弹出属性对话框,如图所示3)选择“Attributes“选项卡,再点击“Add Attributes”工具,弹出如图所示窗口,选择某个属性作为标识符就行了。待续。12PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:数据项、新增数据项、数据项. 第 1 页: 概念数据模型概述 第 2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数据项、新增数据项、数据项的
14、唯一性. 第 6 页: 联系的定义及使用 目标:本小节主要介绍数据项、新增数据项、数据项的唯一性代码选项和重用选项等。一、数据项数据项(Data Item)是信息存储的最小单位,它可以附加在实体上作为实体的属性。注意:模型中允许存在没有附加至任何实体上的数据项。二、新建数据项1)使用“Model”- Data Items 菜单,在打开的窗口中显示已有的数据项的列表,点击 “Add a Row”按钮,创建一个新数据项,如图所示2)当然您可以继续设置具体数据项的 Code、DataType、Length 等等信息。这里就不再详细说明了。三、数据项的唯一性代码选项和重用选项使用 Tools-Mode
15、l Options-Model Settings。在 Data Item 组框中定义数据项的唯一性代13码选项(Unique Code)与重用选项(Allow Reuse)。注意:如果选择 Unique Code 复选框 ,每个数据项在同一个命名空间有唯一的代码,而选择 Allow reuse ,一个数据项可以充当多个实体的属性。四、在实体中添加数据项1)双击一个实体符号,打开该实体的属性窗口。2)单击 Attributes 选项卡,打开如下图所示窗口14注意:Add a DataItem 与 Reuse a DataItem 的区别在于Add a DataItem 情况下,选择一个已经存在的
16、数据项,系统会自动复制所选择的数据项。如果您设置了 UniqueCode 选项,那系统在复制过程中,新数据项的 Code 会自动生成一个唯一的号码,否则与所选择的数据项完全一致。Reuse a DataItem 情况下,只引用不新增,就是引用那些已经存在的数据项,作为新实体的数据项。15PowerDesigner 教程:概念数据模型收藏此页 打印作者:KevinYin 2007-08-27 内容导航:联系的定义及使用 第 1 页: 概念数据模型概述 第 2 页: PowerDesigner 概念数据模型 第 3 页:属性的标准检查约束 第 4 页: 如何定义实体的主、次标识符 第 5 页: 数
17、据项、新增数据项、数据项的唯一性. 第 6 页: 联系的定义及使用 目标:本小节主要介绍联系的定义及使用。 一、 联系联系(Relationship)是指实体集这间或实体集内部实例之间的连接。实体之间可以通过联系来相互关联。与实体和实体集对应,联系也可以分为联系和联系集,联系集是实体集之间的联系,联系是实体之间的联系,联系是具有方向性的。联系和联系集在含义明确的情况之下均可称为联系。按照实体类型中实例之间的数量对应关系,通常可将联系分为 4 类,即一对一(ONE TO ONE)联系、一对多(ONE TO MANY)联系、多对一(MANY TO ONE)联系和多对多联系(MANY TO MANY
18、)。二、 建立联系在 CDM 工具选项板中除了公共的工具外,还包括如下图所示的其它对象产生工具。在图形窗口中创建两个实体后,单击“实体间建立联系”工具,单击一个实体,在按下鼠标左键的同时把光标拖至别一个实体上并释放鼠标左键,这样就在两个实体间创建了联系,右键单击图形窗口,释放 Relationship 工具。如下图所示16三、 四种基本的联系即一对一(ONE TO ONE)联系、一对多(ONE TO MANY)联系、多对一(MANY TO ONE)联系和多对多联系(MANY TO MANY)。如图所示四、 其他几类特殊联系除了 4 种基本的联系之外,实体集与实体集之间还存在标定联系(Ident
19、ify Relationship)、非标定联系(Non-Identify RelationShip)和递归联系(Recursive Relationship)。标定联系:每个实体类型都有自己的标识符,如果两个实体集之间发生联系,其中一个实体类型的标识符进入另一个实体类型并与该实体类型中的标识符共同组成其标识符时,这种联系则称为标定联系,也叫依赖联系。反之称为非标定联系,也叫非依赖联系。注意:在 非标定联系中,一个实体集中的部分实例依赖于另一个实例集中的实例,在这种依赖联系中,每个实体必须至少有一个标识符。而在标定联系中,一个实体集中的全 部实例完全依赖于另个实体集中的实例,在这种依赖联系中一个
20、实体必须至少有一个标识符,而另一个实体却可以没有自己的标识符。没有标识符的实体用它所依赖 的实体的标识符作为自己的标识符。换句话来理解,在标定联系中,一个实体(选课)依赖 一个实体(学生),那么(学生)实体必须至少有一个标识符,而(选课)实体可以没有自己的标识符,没有标标识符的实体可以用17实体(学生)的标识符作为自己的标识符。递归联系:递归联系是实体集内部实例之间的一种联系,通常形象地称为自反联系。同一实体类型中不同实体集之间的联系也称为递归联系。例 如:在“职工”实体集中存在很多的职工,这些职工之间必须存在一种领导与被领导的关系。又如“学生”实体信中的实体包含“班长”子实体集与“普通学生”
21、子 实体集,这两个子实体集之间的联系就是一种递归联系。创建递归联系时,只需要单击“实体间建立联系”工具从实体的一部分拖至该实体的别一个部分即可。如图五、 定义联系的特性在两个实体间建立了联系后,双击联系线,打开联系特性窗口,如图所示。18六、 定义联系的角色名在联系的两个方向上各自包含有一个分组框,其中的参数只对这个方向起作用,Role Name为角色名,描述该方向联系的作用,一般用一个动词或动宾组表。如:“学生 to 课目 ” 组框中应该填写“拥有”,而在“课目 To 学生”组框中填写“属于”。(在此只是举例说明,可能有些用词不太合理)。七、 定义联系的强制性Mandatory 表洋这个方向
22、联系的强制关系。选中这个复选框,则在联系线上产生一个联系线垂直的竖线。不选择这个复选框则表示联系这个方向上是可选的,在联系线上产生一个小圆圈。八、 有关联系的基数联系具有方向性,每个方向上都有一个基数。举例,“ 系”与“学生”两个实体之间的联系是一对多联系,换句话说“学生”和“系”之间的联系是多对一联系。而且一个学生必须属于一个系,并且只能属于一个系,不 能属于零个系,所以从“学生”实体至“系”实体的基数为“1,1”,从联系的另一方向考虑,一个系可以拥有多个学生,也可以没有任何学生,即零个学生,所 以该方向联系的基数就为“0,n”,如图所示19待续。20PowerDesigner UML 建模
23、简介收藏此页 打印作者:David Dichmann 2007-08-28 内容导航:引言 第 1 页: 引言 第 2 页: 对象图 【IT168 技术文档】引言PowerDesigner 支持 UML1.3 的所有图包括用例图、序列图和类图、活动图表和组件图表等,并全面支持 UML2.0。改进了面向对象分析与设计(OOAD)分析方法并增强了与开发过程的集成。 PowerDesigner 能够帮助您构建适应现代 IT 发展的传统商务和电子商务系统,使用 Java 等面向对象的语言以及 XML 等新技术,以物理或虚拟的方式与我们的数据库技术合并。我们的目标是根据您的需求,提供随时随地访问信息、控
24、制业务流程的能力,并通过计算机和最新技术赋 予企业在当今任何市场上先拔头筹的竞争优势。 我们的分析方法和设计技术将会是多种多样的,从业务流程建模,到 UML 面向对象分析和设计,以及传统的关系建模等。本文将帮助您深入了解 UML 这项强大的技术,它可以帮助您的企业创建出高效的传统商务和电子商务系统。 面向对象的分析 在您准备为企业作出系统和软件投资前,必须首先了解企业的实际需求,明确所部署的技术将如何帮助您的企业获取更大的成功。您可以使用 UML,借助用例图、序列图和活动图来进行分析。这些图表将帮助您规划系统的范围、动态性能、以及表现方式等。不必考虑实施细节,您希望获得的只是按照您 的需求而表
25、现的系统性能。 用例图(The Use Case Diagram) UML 用例图提供了一个系统环境的建模方式。它能够帮助您确定系统/应用程序的外部和内部元素以及系统范围。作为图形建模模式,它在您需要与所收集的系统需求进 行对话时也将有所帮助,对于研制成品的开发团队来说,更是有着举足轻重的重要性。对于企业的所有者,或第一次接触该软件产品的用户也有很大的帮助作用。用 例图能够以可视化的方式,表达系统如何满足所收集的业务规则,以及特定的用户需求等信息。 在项目 后期,也能够用到 UML 用例图。您可以通过用例图中定义的需求来协助测试项目的相关功能。您不仅可以验证系统性能是否无错误(无崩溃或明显21
26、的非逻辑响应),还可以验证系统运行时 是否按照要求,执行了指定命令。这样,您可以测试系统是否完全满足了要求,以确信成品可以投入生产也就是说,它已完全满足了用户的需求。 只有确保满足了合理、实用的各项需求,才能确保 IT 项目的更大成功。 序列图(The Sequence Diagram) 您可以使用 UML 序列图细化需求并对设计元素进行链接。序列图允许高层和低层对象间的交互文档。该交互在角色(与用例图中的角色相同)和类实例(运行于计算机内存中的技术对象和细节对象)之间显示。 通 过序列图,您可以按照系统特定方案中事件(消息)的精确顺序来描述随时间变化的系统行为。使用序列图进行用例分析并引导设
27、计:您可以决定将对用22例图所定义 的管理任务负责的系统对象类型,并决定哪种对象将管理系统内外的“会话”或通信。由于消息已从序列图中抽出,您可以描述类和接口(我们最后要编译和部署的 代码元素)所需的某些关键操作(方法)。 活动图(The Activity Diagram) UML 活动图设计用于帮助您了解系统中对象的动态变化。用于描述某一特定类或一组类如何协同工作。与序列图有所不同,活动图不是一系列与时间相关的通信,而是从一个任务到另一任务的控制转移,同时指定谁(哪个对象)对发生的任务负责。 UML 活动图也是业务流程的技术视图。可对业务工作流进行分析或在“业务流程建模”工作后可获得活动图。
28、活动图还可帮助构造系统内元素的详细动态视图(EJB 如何互操作等)。 23通过分析推动设计 通过分析模型可捕获独立于实施细节之外的系统意向和预期行为,与使用的语言、部署的应用程序服务器或使用的体系结构都没有关系。但是,设计阶段开始后,一切都发生了变化。您必须进入生产环境的细节并将软件构建至特定的体系结构。设计是对系统的实施。 如 果设计是由分析得到的,您可以更加确信所编写的系统行为的正确性,确认所开发的成果将是一个按需求构建的系统。您将获得高度成功让用户得到所需要的系 统。您还可以直接利用分析得出的信息而无需在设计过程中重新生成,从而缩减开发时间,由于不必“重新复制”任何工作,因此减少了人为错
29、误。 通过分析,我们可获得什么呢?通过用例图可以发现对象并促进类和接口的创建。一个或更多类和接口可以实现一个角色,您可以在角色定义中直接创建类24和接口。您还可以将角色链接到现有的类和接口,显示如何使用一条代码来满足所分析的多个元素。 通过序列图可以发现方法并促进类操作的创建。如果您需要向类发送消息,您可以调用该类的方法。序列图中的消息可以用来自动创建操作或链接到现有操作。您可以通过链接跟踪方法的功能,包括将哪些作为输入内容和必须返回哪些内容等等。 设计所包含的内容 您 已经知道要构建的内容,现在您需要表述如何构建。您需要确定业务逻辑所在的位置:可以置于应用程序服务器的 EJB 等组件中,也可
30、以置于使用 VB 或 PowerBuilder 等语言、作为客户端应用程序一部分的类或组件中,或者做为触发器和过程内置于关系数据库中。您需要根据需求做出一些选择,包括扩展性、安全、性能和可访问 性等方面。 UML 类图和组件图将用于定义详细的技术系统静态结构。 类图 (The Class Diagram) UML 类图、业务逻辑和所有支持结构一同被用于定义全部的代码结构。既然类图用来模拟开发中所维护的实际代码,显然它是 Java 或 PowerBuilder 等对象语言的概括性表述。您还可以使用 UML 类图来概括 XML 中的复杂结构,令其更易于开发和理解。 可 以从 UML 类图上生成代码
31、。还可以在开发过程中编辑该代码以完善、测试和部署最终运行的应用程序。由于 PowerDesigner 在对象语言和 UML 类图之间具有 1:1 的映射功能,您还可以实施反向工程代码,读取源文件并创建新的类图。您可以更深入地理解现有系统并简化集成和维护工作。 25组件图(The Component Diagram) UML 组件图将被用于在更大的黑匣视图(Black Box View)中描述高级对象的定义和相关性。它仍然是一个设计模型,并且是代码的直接概括。例如,一个 EJB 的组件标识直接链接到实施所必需的一系列类和接口,并将生成所需代码来推动最终 bean 的开发。 26组件图比组件体系结
32、构的代码层视图更容易理解和管理。还可以通过编写组件接口的文档来实现代码的共享和反复使用,用户无需(或很少)了解组件的实施细节即可在其他项目和系统中使用这些代码。 右击 Customer EntityBean_CMP,选择 Create/Update Class Diagram,生成如下 class diagram: 循环叠代工程 世 界不是一成不变的,您的 IT 项目也如此。在您了解需求,通过分析进行了设计,并构建了系统的某些元素后,必然还会遇到新的变化,如要更新定义,又或者现有用例图中存在某些需要改正的 错误,代码在 IDE 和文本编辑器中27被编辑以及数据库被 DBA 优化等。必须管理和掌
33、握所有需要更改的细节,以确保所构建的系统能够与业务需求保持一致。 往返工程的一个方案是当代码在开发过程中被更改时,需要在类图中反映出来。具体细节如下: 1. 创建类图并将业务逻辑元素添加到模型中 2. 生成文件系统的应用程序代码 3. 在 IDE 或文本编辑器中编辑代码 4. 编辑设计,此时忽略在生成的代码中所发生的更改 5. 对编辑内容实施反向工程,直到与现有类图一致 6. 将设计过程中完成的工作与开发时编辑的内容同步(合并) 7. 生成新代码,该代码是设计代码和开发人员更改代码的总和 当对类图进行了修改以反映新的设计内容时,应该使用同步/合并技术防止丢失开发人员的工作成果,同时允许设计人员
34、接受或拒绝开发过程中所做的更改。这样,PowerDesigner 令 IT 能够完全控制体系结构,这正是制胜的关键。 PowerDesigner 的功能并不是仅限于此!现在设计模型已被更新,您可以将这些更改链接到分析中。有可能您在分析中发现了新的需求,可以将这一更改反映到设计中并编写代码。 使用 PowerDesigner 中领先的 Compare/Merge 技术(在 September Blueprint 中讨论过),您可以在开发周期的所有模型和阶段中获得真正的往返同步。 28PowerDesigner UML 建模简介收藏此页 打印作者:David Dichmann 2007-08-28
35、 内容导航:对象图 第 1 页: 引言 第 2 页: 对象图 对象图(Object Diagram) 与类图一样,对象图也是一个 UML 静态结构图;它定义了系统在给定时刻具有的物理元素,而没有具体考虑系统的动态活动。它与代码一一对应,但与类图不同,我们现在讨论的是具体的分类器,而不是分类器定义。将对象图描述为类实例图可能最为合适。 对象图的主要用途是进行分析。类图中无法表示的类之间存在不确定的约束。我们将使用对象图来记录这些约束。而且,在我们查看所管理的具体类实例示例以阐明这些元素之间的交互作用关系时,对象图还允许我们定义具体的“What if”场景。 以 下内容适用于 OO 建模的初学者:
36、分类器是抽象的对象结构定义。分类器可以告诉我们所管理的是什么类型的数据(属性/成员表示数据元素)以及该分类器具有什么能力(操作/方 法表示对象的行为)。实例是具体的分类器示例。假定定义一个名为 Customer 的类,该类具有 Name 属性。类 Customer 的实例“Jane Doe”是姓名恰为“Jane Doe”的客户。实例通常具有比分类器更丰富的含义,这是因为分类器表示某种级别的概述。收集某个分类器的若干个实例或示例可能有助于您理解其用途并更好 地使用它。 因此,对象图是类图的具体形式,表示类实例样本,并且显示了键值和关系。例如,CustomerBean 类具有以下客户实例:该客户的
37、 ID 为 52271,姓名为“John Doe”。该客户实例与三个订单实例(三份订单)相关,订单编号分别为 122047、122103 和 122399。 协作图(Collaboration Diagram) 29协作图和序列图非常相似。实际上,序列图和协作图可以有效地交替使用,并可以简便的相互转换。其区别在于用户阅读和理解的方式不同。序列图具有很好的层次 性,并且围绕时间构造。协作图则主要是围绕对象结构构造。通过在图中对消息进行编号可以表示消息的顺序。采用这种方式时,即使图的结构不是基于时间的,也 将保持定时关系。 协作图借助于系统中元素或对象之间的交互作用,表示系统的动态方面,即在一段时
38、间内的表现方式。它通过表示系统的静态结构来对类图和对象图进行补充,但不是借助于基于结构的关系,而是在系统对象之间传递交互作用“消息”。 构造协作图时还可以在概念级测试静态模型。在类图中定义了类实例,这些类实例之间的交互作用定义了一个具体的使用方案以及将在这些元素之间发生的内部通讯。我们还可以使用其他角色来表示系统的外部作用者和内部使用者,如用例图。 例 如,我们可以建立一个订单输入系统,以供客户和销售代表使用。客户通过创建新订单与该系统交互作用。订单对象与销售对象之间进行对话,该对话由链接消息表 示,在此情况下,只有两个消息:一个是来自 Orders 类的订单请求,一个是来自 Sales 类的
39、订单确认。对一个链接上的消息数量没有限制。我们在此讨论的对话以一个订单请求开始,然后是对该订单的确认。 适用性 协作图对于设计人员尤其重要,因为它阐明了对象的作用。您可以在序列图之前构造协作图(如果您计划构造这两个图),但通常是在完成类图之后构造协作图以说 明从类中导出的对象之间的交互作用。可以使用一个或多个协作图来实现一个用例,或者将复杂行为分割成多个逻辑子行为。 状态图(Statechart Diagram) 状态图(也称为状态机)描述了特定类或组件在其整个生命周期中不断变化时的行为。该图显示是什么触发了从一种状态向另一种状态的转换,以及在该类上调用哪 些操作以提供该状态的行为或触发这种转
40、换。例如,订单在被创建时处于初始状态。在客户确认订单正确后,订单将进入确认状态。在发货以30后,订单需要从确认状 态进入发货状态。 因 此,每当一个类在其生命周期的不同阶段具有不同的可用选项(不同的有效行为)时,您都可以使用状态图来将这些规则和条件建模。生命周期中的每个阶段都是该 对象的一种状态,而每个改变状态的触发器都代表从一种状态到另一种状态的转换。可以根据需要从某个状态转换到任意多个其它状态,也可以从其它多个状态进入 某个状态。 子状态图 若要保持状态图简单和易读,您可能发现所定义的一个或多个状态实际上涉及到更为复杂的行为,以至于它本身就可以定义为一个状态图。此时,与向主图中添加大 量复
41、杂细节的做法相比,更好的做法是将这个单独的状态分解为多个子状态,进而组成一个辅助图,以定义父状态的更为复杂的内部行为。 部署图(Deployment Diagram)部署图可以帮助我们确定所有代码元素在服务器、工作站和数据库中的存放位置。有的节点需要依赖硬件或软件框来运行部分业务逻辑。这些节点交互作用以演示我 们开发的多个计算机和系统是如何交互作用和集成的。节点中包含将部署到数据库、应用程序或 Web 服务器中的组件实例。 部署图用于将组件实际部署到服务器中。通过定义希望组件运行的位置,我们可以快捷的映射、部署和管理分布在客户端应用程序和应用程序服务器端组件之间的业务逻辑或数据库端服务器逻辑。以下是要管理的物理体系结构的 1:1 模型。