PowerDesigner 概念数据模型(CDM)

PowerDesigner 概念数据模型(CDM) 说明

2014-05-07  大数据深...  来源  阅 51 
 

 

关于PowerDesigner的说明参考:数据库

PowerDesigner 15 概述微信

http://blog.csdn.net/tianlesoftware/article/details/6869279网络

 

这篇主要了解一下CDM 模型及使用。数据结构

 

 

1、概念数据模型(CDM)概述

Conceptual Data Model:概念数据模型,它以实体-联系(Entity-RelationShip, E-R)理论为基础,并对这一理论进行了扩充。它从用户的观点出发对信息进行建模,主要用于数据库的概念级设计。

 

一般人们先将现实世界抽象为概念世界,而后再将概念世界转为机器世界。换句话说,就是先将现实世界中的客观对象抽象为实体(Entity)和联系 (Relationship),它并不依赖于具体的计算机系统或某个DBMS系统,这种模型就是咱们所说的CDM;而后再将CDM转换为计算机上某个 DBMS所支持的数据模型,这样的模型就是物理数据模型,即PDM。

ide

CDM是一组严格定义的模型元素的集合,这些模型元素精确地描述了系统的静态特性、动态特性以及完整性约束条件等,其中包括了数据结构、数据操做和完整性约束三部分。工具

1)数据结构表达为实体和属性;大数据

2)数据操做表达为实体中的记录的插入、删除、修改、查询等操做;this

3)完整性约束表达为数据的自身完整性约束(如数据类型、检查、规则等)和数据间的参照完整性约束(如联系、继承联系等)spa

 

 

2、实体、属性及标识符的定义

2.1 实体(Entity):.net

也称实例,对应现实世界中可区别于其余对象的“事件”或“事物”。例如,学校中的每一个学生,医院中的每一个手术。每一个实体都有用来描述实体特征的一组性质,称之为属性,一个实体由若干个属性来描述。如学生实体可由学号、姓名、性别、出生年月、所在系别、入学年份等属性组成。

2.2 实体集(EntitySet):

是具体相同类型及相同性质实体的集合。例如学校全部学生的集合可定义为“学生”实体集,“学生”实体集中的每一个实体均具备学号、姓名、性别、出生年月、所在系别、入学年份等性质。

 

2.3 实体类型(EntityType):

是实体集中每一个实体所具备的共同性质的集合,例如“患者”实体类型为:患者{门诊号,姓名,性别,年龄,身份证号.............}。实体是实体类型的一个实例,在含义明确的状况下,实体、实体类型一般互换使用。实体类型中的每一个实体包含惟一标识它的一个或一组属性,这些属性称为实体类型的标识符(Identifier),如“学号”是学生实体类型的标识符,“姓名”、“出生日期”、“信址”共同组成“公民”实体类型的标识符。有些实体类型能够有几组属性充当标识符,选定其中一组属性做为实体类型的主标识符,其余的做为次标识符。

 

3、实体、属性及标识符的表达

 

 

 

4、新建概念数据模型

4.1选择File-->New,弹出如图所示对话框,选择CDM模型(即概念数据模型)创建模型。

 



4.2 完成概念数据模型的建立。如下图示,对当前的工做空间进行简单介绍。

 

4.3 选择新增的CDM模型,右击,在弹出的菜单中选择“Properties”属性项,弹出如图所示对话框。在“General”标签里能够输入所建模型的名称、代码、描述、建立者、版本以及默认的图表等等信息。在“Notes”标签里能够输入相关描述及说明信息。固然再有更多的标签,能够点击 "More>>"按钮,这里就再也不进行详细解释。


5、定义实体

5.一、建立实体

1)在CDM的图形窗口中,单击工具选项版上的Entity工具,再单击图形窗口的空白处,在单击的位置就出现一个实体符号。点击Pointer工具或右击鼠标,释放Entitiy工具。如图所示

 

 

PowerDesigner工具面板association,inheritance,association link 不可用 解决方法

http://blog.csdn.net/tianlesoftware/article/details/6870263

 

2)双击刚建立的实体符号,打开下列图标窗口,在此窗口“General”标签中能够输入实体的名称、代码、描述等信息。

Name:是用来在模型中标识一个实体,通常用于模型在界面中的显示(这个能够经过更改选项设置进行改变)。在一个模型当中,实体的名字不能重复。

Code:在模型转化时通常做为对象的物理名称,好比把实体属性的Code转化为数据库中的列名。

Generate:默认是选择状态,若是取消,则在转化为其余模型时,会忽略这个实体。

 

5.二、添加实体属性

1)在上述窗口的“Attribute”选项标签上能够添加属性,以下图所示。



注意:

数据项中的“添加属性”和“重用已有数据项”这两项功能与模型中Data Item的Unique code 和Allow reuse选项有关。

P 列表示该属性是否为主标识符;

D列表示该属性是否在图形窗口中显示;

M列表示该属性是否为强制的,即该列是否为空值。

 

若是一个实体属性为强制的,那么,这个属性在每条记录中都必须被赋值,不能为空。

按“Crtl+U”呼出“定制列过滤器”的窗口,能够根据本身的喜爱和实际须要选择那些列出如今窗口中,那些隐藏。使用快捷键“Crtl+E”能够容许或者禁止当前过滤器。

 

2)在上图所示窗口中,点击插入属性按钮,弹出属性对话框,以下图所示。

 

 

5.三、定义属性的检查约束

1)定义属性的标准检查

标准检查约束是一组确保属性有效的表达式。在实体属性的特性窗口,打开如图所示的检查选项卡。



在这个选项卡能够定义属性的标准检查约束,窗口中每项的参数的含义,以下

参数

说明

Minimum

属性可接受的最小数

Maximum 

属性可接受的最大数

Default

属性不赋值时,系统提供的默认值

Unit

单位,如千米、吨、元

Format

属性的数据显示格式

Lowercase

属性的赋值所有变为小写字母

Uppercase

属性的赋值所有变为大写字母

Cannot modify

该属性一旦赋值不能再修改

List Of Values

属性赋值列表,除列表中的值,不能有其余的值

Label

属性列表值的标签

 

2)定义属性的附加检查

当Standard checks 或Rules 不能知足检查的要求时,能够在Additional Checks选项卡的Server子页上,经过SQL语句中使用%MINMAX%、%LISTVAL%、%RULES%、%UPPER%、%LOWER% 几个变量来定义Standard和Rule,如图所示



%MINMAX%、%LISTVAL%、%UPPER%、%LOWER%:

在Standard Check中定义的Minimum 和Maximum、List values 、uppervalues、lowervalues

%RULES%:

在Rules特性窗口Expression选项卡中定义的有效性规则表达式

 

6、标识符

标识符是实体中一个或多个属性的集合,可用来惟一标识实体中的一个实例。要强调的是,CDM中的标识符等价于PDM中的主键或候选键。每一个实体都必须至少有一个标识符。若是实体只有一个标识符,则它为实体的主标识符。若是实体有多个标识符,则其中一个被指定为主标识符,其他的标识符就是次标识符了。

 

6.一、定义主、次标识符

1)选择某个实体双击弹出实体的属性对话框。在Identifiers选项卡上能够进行实体标识符的定义。以下图所示



2)选择第一行“主标识符”,点击属性按钮或双击第一行“主标识符”,弹出属性对话框,如图所示

 

 

3)选择"Attributes"选项卡,再点击“Add Attributes”工具,弹出如图所示窗口,选择某个属性做为标识符就好了。

 

 

7、数据项

数据项(Data Item)是信息存储的最小单位,它能够附加在实体上做为实体的属性。

注意:模型中容许存在没有附加至任何实体上的数据项。

 

7.1 新建数据项

1)使用“Model”---> Data Items 菜单,在打开的窗口中显示已有的数据项的列表,点击 “Add a Row”按钮,建立一个新数据项,如图所示

 



2)固然您能够继续设置具体数据项的Code、DataType、Length等等信息。这里就再也不详细说明了。

 

7.2 数据项的惟一性代码选项和重用选项

使用Tools--->ModelOptions->Model Settings。在Data Item组框中定义数据项的惟一性代码选项(Unique Code)与重用选项(Allow Reuse)。

 

注意:

若是选择Unique Code复选框 ,每一个数据项在同一个命名空间有惟一的代码,而选择Allow reuse ,一个数据项能够充当多个实体的属性。

 

7.3 在实体中添加数据项

1)双击一个实体符号,打开该实体的属性窗口。
2)单击Attributes选项卡,打开以下图所示窗口



注意:Add aDataItem 与 Reuse aDataItem的区别在于

Add a DataItem 状况下,选择一个已经存在的数据项,系统会自动复制所选择的数据项。若是您设置了UniqueCode选项,那系统在复制过程当中,新数据项的Code会自动生成一个惟一的号码,不然与所选择的数据项彻底一致。

 Reuse a DataItem状况下,只引用不新增,就是引用那些已经存在的数据项,做为新实体的数据项。

 

8、 联系

联系(Relationship)是指实体集这间或实体集内部实例之间的链接。

 实体之间能够经过联系来相互关联。与实体和实体集对应,联系也能够分为联系和联系集,联系集是实体集之间的联系,联系是实体之间的联系,联系是具备方向性的。联系和联系集在含义明确的状况之下都可称为联系。

 

按照实体类型中实例之间的数量对应关系,一般可将联系分为4类:

一对一(ONE TO ONE)联系、

一对多(ONE TO MANY)联系、

多对一(MANY TO ONE)联系

多对多联系(MANY TO MANY)。

 

8.一、创建联系

在CDM工具选项板中除了公共的工具外,还包括以下图所示的其它对象产生工具。

 

在图形窗口中建立两个实体后,单击“实体间创建联系”工具,单击一个实体,在按下鼠标左键的同时把光标拖至别一个实体上并释放鼠标左键,这样就在两个实体间建立了联系,右键单击图形窗口,释放Relationship工具。以下图所示

在两个实体间创建了联系后,双击联系线,打开联系特性窗口,如图所示。

 

 

8.二、 四种基本的联系

即一对一(ONE TOONE)联系、一对多(ONE TO MANY)联系、多对一(MANYTO ONE)联系和多对多联系(MANY TO MANY)。如图所示

 

8.三、 其余几类特殊联系

 

除了4种基本的联系以外,实体集与实体集之间还存在标定联系(Identify Relationship)、非标定联系(Non-Identify RelationShip)和递归联系(Recursive Relationship)。

8.3.1 标定联系和非标定联系:

每一个实体类型都有本身的标识符,若是两个实体集之间发生联系,其中一个实体类型的标识符进入另外一个实体类型并与该实体类型中的标识符共同组成其标识符时,这种联系则称为标定联系,也叫依赖联系。反之称为非标定联系,也叫非依赖联系。

 

 注意:

在非标定联系中,一个实体集中的部分实例依赖于另外一个实例集中的实例,在这种依赖联系中,每一个实体必须至少有一个标识符。而在标定联系中,一个实体集中的所有实例彻底依赖于另个实体集中的实例,在这种依赖联系中一个实体必须至少有一个标识符,而另外一个实体却能够没有本身的标识符。没有标识符的实体用它所依赖的实体的标识符做为本身的标识符。

换句话来理解,在标定联系中,一个实体(选课)依赖一个实体(学生),那么(学生)实体必须至少有一个标识符,而(选课)实体能够没有本身的标识符,没有标标识符的实体能够用实体(学生)的标识符做为本身的标识符。

 

 

8.3.2 递归联系:

递归联系是实体集内部实例之间的一种联系,一般形象地称为自反联系。同一实体类型中不一样实体集之间的联系也称为递归联系。

 

例如:在“职工”实体集中存在不少的职工,这些职工之间必须存在一种领导与被领导的关系。又如“学生”实体信中的实体包含“班长”子实体集与“普通学生”子实体集,这两个子实体集之间的联系就是一种递归联系。建立递归联系时,只须要单击“实体间创建联系”工具从实体的一部分拖至该实体的别一个部分便可。如图



联系符号说明:

在Power Designer中,关系符号靠近实体端的一个“横线”表明强制性约束,“空心圆圈”表明无强制约束,即这一方能够无对象关联;“非分岔”线表明为“1” 的关系,“分岔”线表明“多”的关系。以上四个符号共能够组合出16种关系(包含反向)。其中“多对多”的关系通常经过给出一个中间实体来进行分解,因此在许多概念图中,是看不到实际的“多对多”的关系存在的。

 

 

 

 

 

 

 

整理自网络

-------------------------------------------------------------------------------------------------------

Blog: http://blog.csdn.net/tianlesoftware

Weibo: http://weibo.com/tianlesoftware

Email: dvd.dba@gmail.com

DBA1 群:62697716(满);   DBA2 群:62697977(满)  DBA3 群:62697850(满)  

DBA 超级群:63306533(满);  DBA4 群:83829929(满) DBA5群: 142216823(满) 

DBA6 群:158654907(满)   DBA7 群:69087192(满)  DBA8 群:172855474

DBA 超级群2:151508914  DBA9群:102954821     聊天 群:40132017(满)

--加群须要在备注说明Oracle表空间和数据文件的关系,不然拒绝申请

相关文章
相关标签/搜索