使用 Power Designer 16 设计数据库

使用 PowerDesigner 做数据库设计,主要用到两个大的模型:

  • 第一个是 CDM:概念模型;
  • 第二个是 PDM:物理模型。

整体的步骤如下:

  1. 先创建 CDM;
  2. 然后把 CDM 转化成 PDM ;
  3. 最后把 PDM 转化成数据库 sql 执行语句;
  4. 还可以把 PDM 转化成 word 文档。

所以本文也分为 4 个步骤介绍。

一、创建概念模型

打开之后,选择创建概念模型:
概念模型
修改名称之后点击 OK:
修改名称
可以在 Domain 中设置常用的数据格式:
Domain设置
设置常用的格式
这样以后我们创建的实体属性会继承这里的数据类型和长度。

然后点击右上角的表格,再在屏幕中点一下,从而创建一个实体:
创建实体
实体
然后点一下右键,恢复到箭头模式。

双击实体进行设置:

学生表
可以设置表的名字,代码名称,和简介。

然后可以设置属性,但是属性没显示全,我们可以通过点击小漏斗,将我们需要的打钩:
属性
这个时候我们可以手动输入数据类型和长度,但是我们之前设置过 Domain,所以可以直接选择即可:
设置数据类型
同时注意修改 code 为英文,因为 Name 可以是中文,code 不行。

再说一些中间几个字母表示的含义:
字母的含义

  • P 是 Primary Identifier 是否为主键表述的缩写,勾选了 P 就代表当前被勾选字段是该表的主键。
  • M 是 Mandatory 的缩写,勾选表示非空约束。
  • D 是 displayed 的缩写,表示是否在实体图形符号中显示该属性。

最后我们再设置一下这个主键即可,它可以在关系图中,一下子就能清楚地看到某个表的主键是哪个:
设置主键
现在我们又两张表,可以设置关系了:
关系
点击之后长按鼠标即可设置关系:
长按鼠标
关系
这里先介绍一下几个属性的含义:

  1. mandatory
    联系是否具有强制性,指的是实体间是不是一定会出现这种联系;或者换句话说,当我们在谈及一个联系的应用场景的时候,联系对应的那两个实体型的实体实例的个数可不可能为零。也许这样的解释还是有点抽象,让我们举两个联系的例子,一个是对两边的实体都有强制性的,另一个则不然。
    • 教师——学生 联系
      这个联系首先是一个多对多联系,因为每个老师可以教多个学生,每个学生也都有多个老师来负责他们的学业。同时,这个联系对教师和学生都是强制性的,也就是说,不存在任何一个老师,他不负责任何一个学生的教学;也不存在任何一个学生,他没有任何一个任课老师。
    • 学生——俱乐部 联系
      这个联系也是一个多对多关系,但它对学生这个实体型而言就不是强制的(Optional,可选的)。每个俱乐部都有至少一个学生参加,但并不是每个学生都要去参加俱乐部的活动。完全可以有一些学生,他们什么俱乐部都没参加。

上面的例子主要是从概念的角度来区分了mandatory和optional的区别。实际上如果把这个模型对应到我们最后生成的表,如果A-B间的联系对A是mandatory的话,那么如果在A里面如果包含B的外键,这个外键不能为空值,反之可以为空值。后面我们谈到PDM和实际数据库的时候,大家会看到这一点。

  1. dependent
    每一个 Entity 型都有自己的 Identifier,如果两个 Entity 型之间发生关联时,其中一个 Entity 型的 Identifier 进入另一个 Entity 型并与该 Entity 型中的 Identifier 共同组成其 Identifier 时,这种关联称为标定关联,也叫 依赖性关联(dependent relationship)。一个 Entity 型的 Identifier 进入另一个 Entity 型后充当其非 Identifier 时,这种关联称为非标定关联,也叫非依赖关联。
    概念的定义说起来还是有些拗口,说白了其实就是 主-从表关系 ,从表要依赖于主表。 比如在我们系统里要记录教师休假的情况,有一个实体型 Holiday,其属性包括休假的开始时间和天数,每次有教师休假的时候,都要在这个表留下记录。从我们的场景描述中可以看到,实体型假期必须依附于实体型教师,即对于每一个假期实例,必须指向某一个教师实例。

对于依赖型联系,必须注意它不可能是一个多对多联系,在这个联系中,必须有一个作为主体的实体型。一个 dependent 联系的从实体可以没有自己的 identifier。

  1. dominant
    这个联系属性是最为简单的,它仅作用于一对一联系,并指明这种联系中的主从表关系。在A,B两个实体型的联系中,如果 A–>B 被指定为 dominant,那么A为这个一对一联系的主表,B为从表,并且在以后生成的PDM中会产生一个引用(如果不指定dominant属性的话会产生两个引用)。比如老师和班级之间的联系,因为每个班级都有一个老师做班主任,每个老师也最多只能做一个班级的班主任,所以是一个一对一关系。同时,我们可以将老师作为主表,用老师的工号来唯一确定一个班主任联系。

学生表和班级表是多对一的关系,所以可以选择这个:
多对一
课程和学生是多对多的关系:
多对多
值得一提的是我们在设计概念模型的时候不用考虑外键约束和中间表的问题,因为转化为物理模型的时候会自动生成,我们只需要设置好关系即可。

简单的表结构
到此为止 CDM 就设计好了。

二、创建物理模型

PDM 可以直接创建,也可以从 CDM 之间生成,还可以从已有的 PDM 再次生成 PDM 。

在 PDM 中可以对 CDM 生成的表结构,做进一步的核对、确认一下,这是不是就是自己想要的数据结构,需要注意的是 CDM 中的关联 association 会直接生成对应的表 table,还有一点需要注意,如果一个表中有两个来自同一个表的外键,外键的命名还需要人为的手动修改一下。

我们这里直接使用 CDM 生成 PDM:
生成 PDM
点卡之后可以设置数据库和姓名:
数据库
在第二个选项卡中还可以设置表的前缀:
表的前缀
最后点击确定开始生成,如果没有报错,就是白色的输出页面:
执行结果
这是就发现已经生成完了,一对多自动增加了外键约束,多对多自动增加了一张中间表。

PDM

三、导出 SQL 脚本

从 PDM 生成 SQL 语句:

入口
在预览中可以查看最终生成的结构,如果没问题就执行:
预览

四、制作 Word 文档

如果是第一次生成文档则先点击这个:
文档按钮
点击这里新建一个自己的模板:

关于文档模板的制作大家可以参考这篇文章,我觉得写得很清楚,就不过多介绍了:https://cloud.tencent.com/developer/article/1468017

搞好模板之后点击生成:
生成
选择刚刚的文件夹下的模板即可:
设置
设置为中文格式和姓名,以及生成的格式。

最终效果:

在CSDN上转悠经常看到有网友寻求PowerDesigner相关资料的帖子,Baidu,Google上找找还真很少;同时也有不少网友发来Email询问相关PowerDesigner问题或索要相关资料的,故下定决心制作本文档。折腾二十多天,终于输出了现在的文档,其中绝大部分内容都是依照PowerDesigner自带的帮助文档翻译过来,乐意啃英文的朋友最好还是看其”原汁”教程,同时本文档仅用于帮助分析设计人员更快熟悉掌握PowerDesigner使用方法,不包含分析设计方面的理论,所以要作好系统的分析设计工作还是需要用户深厚的项目实践功底。 起初想尽量按照PowerDesigner自带帮助文档完整地进行,尝试了一上午的工作之后这种方案马上就被我否决,原因有二:1.内容太多,工作量太多。2.原帮助文档特别周全,个人觉得可以在内容上作很大程度的压缩。姑决定按原帮助文档写,同时加入自己目前正在做的技术论坛分析设计过程以便于理解。 对本文档内容的几点说明: 1. 本文档只包括PowerDesigner部分内容(RQM,Report,CDM,PDM),内容不够全面。 2. 内容尽量简略,一些相同或类似操作过程尽量不再重复。 3. 部分术语参考了飞思科技产品研发中心监制电子工业出版社的《PowerDesigner数据库系统分析设计与应用》。 4. 暂时没有包含OOM,XML,BPM,ILM等模型内容,我将会在后期陆续更新。 版本说明:我使用的是PowerDesigner Trial 11英文版,因此文档中一些菜单,按钮名称也用英文写出(因当心自己译出的名称和中文版上的名称不一致而造成理解不便),若是给使用中文版的朋友带来不便,我在这说声”抱歉”了!同时由于各版本不同部分操作可能会有所区别。 这里要感谢在我进行翻译工作期间给我发送Email关注的网友,感谢一直支持我的朋友们!由于第一次做翻译工作,限于水平有限,文档中肯定存在很多不足和错误之处,衷心欢迎各位网友指点迷津,期望得到您的指导!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

硕子鸽

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

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

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

打赏作者

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

抵扣说明:

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

余额充值