PowerDesigner 面向对象模型(OOM)

时间:2021-08-28 09:23:27
 

目录(?)[+]

 

一.     OOM 简介

Object-OrientedModel(OOM) 面向对象模型,一个OOM包含一系列包,类,接口 , 和他们的关系。 这些对象一起形成所有的 ( 或部份) 一个软件系统的逻辑的设计视图的类结构。 一个OOM本质上是软件系统的一个静态的概念模型。

(1)利用UML描述系统结构

(2)利用类图生成不同语言的源文件(如Java、C#、PowerBuilder等),或利用逆向工程将不同类型的源文件转换成相应的类图。

1.1 创建OOM

(1)选择File→New Model菜单项

(2)在左侧Model type中选择“Object-Oriented Model”(面向对象模型)

(3)在右侧输入模型名称,选择语言

(4)选择类型

1.2 设计用例图

(1)定义用例

(2)定义角色

(3)定义关联

1.3 设计序列图

(1)定义角色

(2)定义对象

(3)定义消息

(4)定义激活期

1.4  设计类图

(1)定义类

(2)定义属性

(3)定义标识符

(4)定义操作

(5)定义接口

(6)创建联系

1)  关联

2)  依赖

3)  泛化

4)  实现

1.5  生成代码

(1)选择Language→Generate Java Code

(2)选择类

(3)设置生成选项

(4)生成代码

(5)查看生成的代码

二.     示例

2.1 创建OOM

File--> new model

PowerDesigner 面向对象模型(OOM)

这里选择我们的OOM 类型使用默认的Class Diagram, 语言选择Java。

2.2  OOM 生成Java 代码

通过工具面板创建一个类,如下图:

PowerDesigner 面向对象模型(OOM)

双击类,就可以编辑相关的属性。

给类添加变量:

PowerDesigner 面向对象模型(OOM)

如果我们想给类添加方法:

PowerDesigner 面向对象模型(OOM)

先写上方法名称,以及方法的返回类型,然后点击上图的第二步,修改该方法的对应属性:

PowerDesigner 面向对象模型(OOM)

修改方法的内容:

PowerDesigner 面向对象模型(OOM)

这里的方法名称不能修改,在这一步我们只能修改方法对应的代码。

如果要给方法添加参数:

PowerDesigner 面向对象模型(OOM)

完成配置之后:

PowerDesigner 面向对象模型(OOM)

现在导出将我们创建的类导成Java代码:

Language--> Generate Java Code.  生成Java 代码。

PowerDesigner 面向对象模型(OOM)

生成的代码如下:

[java] view plaincopy
  1. /***********************************************************************
  2. *Module:  Student.java
  3. *Author:  Administrator
  4. *Purpose: Defines the Class Student
  5. ***********************************************************************/
  6. import java.util.*;
  7. /** @pdOid4a8af797-2729-419d-9751-2c15a1baef8e */
  8. public class Student {
  9. /** @pdOid 52d32718-cd89-4b1c-8c46-0f4fa83b0dac */
  10. private int id;
  11. /** @pdOid 5a14a55f-4d17-41ea-ad64-05a0c4f5c523 */
  12. private String name;
  13. /** @pdOid 46fb39fd-e50e-4166-9cdb-b7ae3bfdd229 */
  14. private int sex;
  15. /** @pdOid 5e139923-641e-45f0-ba19-773495078f63 */
  16. private Number phone;
  17. /** @pdOid 540722b0-789c-491a-a145-a92226843e0a */
  18. private String address;
  19. /**@param type
  20. *@pdOid e610d773-1a41-4f42-b5b7-f932b24fa6ec */
  21. public String helloWorld(int type) {
  22. // TODO: implement
  23. String str='Hello World!';
  24. return str;
  25. }
  26. /** @pdOid 9108fb19-6b33-4cfa-b629-bd6dc474abd0 */
  27. public void helloWorld2() {
  28. System.out.println("Hello World!");
  29. }
  30. }

2.3  从Java 类生成OOM

这个是我要导入的Java 代码:

[java] view plaincopy
  1. package cn.jsprun.service;
  2. import java.util.ArrayList;
  3. import java.util.HashMap;
  4. import java.util.List;
  5. import java.util.Locale;
  6. import java.util.Map;
  7. import org.apache.struts.util.MessageResources;
  8. import cn.jsprun.dao.DataBaseDao;
  9. import cn.jsprun.dao.OnLineListDao;
  10. import cn.jsprun.domain.Onlinelist;
  11. import cn.jsprun.domain.OnlinelistId;
  12. import cn.jsprun.utils.BeanFactory;
  13. import cn.jsprun.utils.Common;
  14. import cn.jsprun.vo.otherset.OnlinelistVO;
  15. public class OnLineSetService {
  16. privatefinal String tablePrefix = "jrun_";
  17. publicList<OnlinelistVO> queryAllSystemUserGroup(MessageResources mr,Localelocale){
  18. List<Map<String,String>>usergroupMapList = ((DataBaseDao)BeanFactory.getBean("dataBaseDao")).executeQuery("SELECTu.groupid,u.grouptitle FROM "+tablePrefix+"usergroups AS u WHEREu.type<>'member'");
  19. List<Onlinelist>onlinelist_list =((OnLineListDao)BeanFactory.getBean("onLineListDao")).queryAllOnlineList();
  20. Map<String,Onlinelist>onlinelistMap = new HashMap<String, Onlinelist>();
  21. for(Onlinelistonlinelist : onlinelist_list){
  22. onlinelistMap.put(onlinelist.getId().getGroupid().toString(),onlinelist);
  23. }
  24. List<OnlinelistVO>onlinelistVO_list = new ArrayList<OnlinelistVO>();
  25. Onlinelistonlinelist = null;
  26. OnlinelistIdonlinelistId = null;
  27. OnlinelistVOonlinelistVO = null;
  28. Stringgroupid = null;
  29. StringquondamTitle = null;
  30. Stringdisplayorder = null;
  31. Stringtitle = null;
  32. Stringurl = null;
  33. onlinelist= onlinelistMap.get("0");
  34. StringnormalUser = mr.getMessage(locale, "usergroups_system_0");
  35. if(onlinelist!=null){
  36. onlinelistId= onlinelist.getId();
  37. onlinelistVO= new OnlinelistVO();
  38. onlinelistVO.setDisplayorder(onlinelistId.getDisplayorder().toString());
  39. onlinelistVO.setGroupid("0");
  40. onlinelistVO.setQuondamTitle(normalUser);
  41. onlinelistVO.setTitle(onlinelistId.getTitle());
  42. onlinelistVO.setUrl(onlinelistId.getUrl());
  43. onlinelistVO_list.add(onlinelistVO);
  44. }else{
  45. onlinelistVO= new OnlinelistVO();
  46. onlinelistVO.setDisplayorder("");
  47. onlinelistVO.setGroupid("0");
  48. onlinelistVO.setQuondamTitle(normalUser);
  49. onlinelistVO.setTitle(normalUser);
  50. onlinelistVO.setUrl("");
  51. onlinelistVO_list.add(onlinelistVO);
  52. }
  53. for(Map<String,String>usergroupMap : usergroupMapList){
  54. onlinelistVO= new OnlinelistVO();
  55. groupid= usergroupMap.get("groupid");
  56. Stringgrouptitle = usergroupMap.get("grouptitle");
  57. switch(Short.parseShort(groupid)) {
  58. case1:
  59. quondamTitle= mr.getMessage(locale, "usergroups_system_1");
  60. break;
  61. case2:
  62. quondamTitle= mr.getMessage(locale, "usergroups_system_2");
  63. break;
  64. case3:
  65. quondamTitle= mr.getMessage(locale, "usergroups_system_3");
  66. break;
  67. case4:
  68. quondamTitle= mr.getMessage(locale, "usergroups_system_4");
  69. break;
  70. case5:
  71. quondamTitle= mr.getMessage(locale, "usergroups_system_5");
  72. break;
  73. case6:
  74. quondamTitle= mr.getMessage(locale, "usergroups_system_6");
  75. break;
  76. case7:
  77. quondamTitle= mr.getMessage(locale, "guest");
  78. break;
  79. case8:
  80. quondamTitle= mr.getMessage(locale, "usergroups_system_8");
  81. break;
  82. default:
  83. quondamTitle= grouptitle;
  84. }
  85. onlinelist= onlinelistMap.get(groupid);
  86. if(onlinelist==null){
  87. displayorder="";
  88. title= grouptitle;
  89. url= "";
  90. }else{
  91. onlinelistId= onlinelist.getId();
  92. displayorder= onlinelistId.getDisplayorder().toString();
  93. title= onlinelistId.getTitle();
  94. url= onlinelistId.getUrl();
  95. }
  96. onlinelistVO.setDisplayorder(displayorder);
  97. onlinelistVO.setGroupid(groupid);
  98. onlinelistVO.setQuondamTitle(quondamTitle!=null?quondamTitle.replace("&","&").replace("<","<").replace(">",">").replace("\"","""):null);
  99. onlinelistVO.setTitle(title!=null?title.replace("\"","""):null);
  100. onlinelistVO.setUrl(url!=null?url.replace("\"","""):null);
  101. onlinelistVO_list.add(onlinelistVO);
  102. }
  103. returnonlinelistVO_list;
  104. }
  105. publicvoid updateOnLineList(String delGroupids , List<Onlinelist> updateList,List<Onlinelist> addList) {
  106. DataBaseDaodataBaseDao = (DataBaseDao)BeanFactory.getBean("dataBaseDao");
  107. if(delGroupids!=null){
  108. dataBaseDao.executeDelete("DELETEFROM "+tablePrefix+"onlinelist WHERE groupidIN("+delGroupids+")");
  109. }
  110. OnlinelistIdonlinelistId = null;
  111. for(Onlinelistonlinelist : updateList){
  112. onlinelistId= onlinelist.getId();
  113. dataBaseDao.execute("UPDATE"+tablePrefix+"onlinelist SETtitle='"+Common.addslashes(onlinelistId.getTitle())+"',url='"+Common.addslashes(onlinelistId.getUrl())+"',displayorder="+onlinelistId.getDisplayorder()+" WHEREgroupid="+onlinelistId.getGroupid());
  114. }
  115. if(addList.size()>0){
  116. ((OnLineListDao)BeanFactory.getBean("onLineListDao")).addOnlinelist(addList);
  117. }
  118. }
  119. }

选择Language –>Reverse Engineer Java, 将我们要导入的java 代码添加进来,确定:

PowerDesigner 面向对象模型(OOM)

PowerDesigner 面向对象模型(OOM)

这里把包的结构也生成了,我们看这个类具体的一些属性,双击类:

有一个变量:

PowerDesigner 面向对象模型(OOM)

两个方法:

PowerDesigner 面向对象模型(OOM)

PowerDesigner 面向对象模型(OOM)

PowerDesigner 面向对象模型(OOM)

2.4 OOM 生成Java 代码格式说明

从2.2 节导出的代码来看,默认的生成代码模板也不十分清晰。 如果我们要修改这个默认的模板,可以按照一下方法来操作:

Language--> Edit Current Object Language

然后:

profile>class>templates>definition

PowerDesigner 面向对象模型(OOM)

修改这里面的样式就ok了。 我现在也不折腾Java 代码,具体样式这块就各位同学自己折腾了。

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

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

Weibo: http://weibo.com/tianlesoftware

Email: tianlesoftware@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表空间和数据文件的关系,否则拒绝申请