目录(?)[+]

 

一. 正向工程与逆向工程说明

在前面几篇里介绍了几个PowerDesigner的常用模型,参考:

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

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

PowerDesigner 物理数据模型(PDM) 说明

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

PowerDesigner 面向对象模型(OOM)说明

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

PowerDesigner 业务处理模型( BPM ) 说明

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

PowerDesigner 企业架构模型 ( EAM ) 说明

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

正向工程和逆向工程就是上面几个模型相互之间转换的过程。

正向工程:

CDM—>PDM

PDM—> Database

PDM—>OOM

从CDM 到PDM 也是软件工程中推荐的一种方法,不过在实际的项目中,很少有公司会按照这个流程来走,甚至连E-R图都不画,直接上来就建表。

逆向工程:

(1)    从处理语言(Process Language)逆向生成业务处理模型(BPM)

(2)    从对象语言(Object Language)逆向生成面向对象模型(OOM)

(3)    从数据库(Database)或数据库脚本逆向生成物理数据模型(PDM)

(4)    从XML定义(XMLDifinition)逆向生成XML模型

二. 示例

在这里演示2个例子:

(1)    CDM --> PDM --> Database.

(2)    Database --> PDM --> CDM

2.1 正向工程:CDM –>PDM –> Database示例

PD 自带的示例CDM:

我们将这个CDM 转换称PDM:  Tools --> Generate Physical Data Model.

生成的PDM 图如下:

再将我们的PDM 生成对应的SQL 脚本: Database –> Generate Database

这里有两种选择,一种是生成脚本,即Script generation,还有一种是直接在数据库里生成,即directory generate,一般都是先生成SQL 脚本,然后在数据库执行脚本。

以上就是一个典型的过程,也是软件工程中建议的一种流程。

2.2 逆向工程:Database  --> PDM --> CDM

在2.1 节讲了正向工程的一些概念,即从CDMàPDM à DATABASE. 如果严格按照这个过程来执行,在后期还可以参考这些Model。但是在国内的软件开发流程中,只有少数的公司会按照这个流程来走,那么大多数情况都是拿到需求分析后直接在数据库里建表。

如果某个线上的系统,就是这么设计出来的,那么这时候,我们要得到它的PDM,就可以使用PD的逆向工程来实现。

先连上测试环境,新建一个用户,然后把我们2.1 节导入的脚本执行一遍:

  1. C:\Users\Administrator.DavidDai>sqlplussys/oracle@RAC as sysdba;
  2. SQL*Plus: Release 11.2.0.1.0 Production onTue Oct 18 13:37:17 2011
  3. Copyright (c) 1982, 2010, Oracle.  All rights reserved.
  4. Connected to:
  5. Oracle Database 10g Enterprise EditionRelease 10.2.0.4.0 - Production
  6. With the Partitioning, Real ApplicationClusters, OLAP, Data Mining
  7. and Real Application Testing options
  8. SQL> create user pd identified by pd;
  9. User created.
  10. SQL> grant connect,resource,dba to pd;
  11. Grant succeeded.
  12. SQL> conn pd/pd@RAC;
  13. Connected.
  14. SQL> @d:\crebas.sql

脚本执行完毕后,相关的表和索引已经创建完成,现在我们使用PD 来进行逆向工程操作。

File —> Reverse Engineer –>Database

修改PDM 模块名称和 DBMS 类型,这里是Oracle 10gR2:

配置数据源:

Connection profile name: 生成连接文件名称

Directory:生成连接文件保存位置,我这里保存到桌面

Connection type:连接类型,可是使用Native(tnsnames.ora)或者JDBC。

确定之后进行reverse。具体需要的时间要根据数据库对象的多少来定。 我的这个测试,不到1分钟就搞完了。

逆向工程之后的PDM 如下图:

在将PDM 转成CDM:

最终的CDM 如下:

正向工程与逆向的工程就这么多,更多内容就各位同学自己研究了。

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

版权所有. 文章允许转载,但必须以链接方式注明源地址,否则追究法律责任.

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

Weibo: http://weibo.com/tianlesoftware

Email: tianlesoftware@gmail.com

PowerDesigner 正向工程 和 逆向工程 说明的更多相关文章

  1. 正向工程、逆向工程与MDA

    正向工程.逆向工程与MDA 正向工程:从UML图形生成代码: 逆向工程:从代码和成UML图形: //不要依赖于正向或逆向工程,仅是一种辅助手段.画图的目的不是为了生成代码:而写代码的目的也不是为了生成 ...

  2. powerDesigner 正向工程生成sql注释

    找到script-->objects-->column-->add value内容如下: %:COLUMN% %:DATATYPE%[.Z:[%Compressed%? compre ...

  3. PowerDesigner 对 Oracle 作 逆向工程

    原文 PowerDesigner 对 Oracle 作 逆向工程 目的 PowerDesigner 15对OracleClient 11g进行逆向工程 环境 Win7 64位系统 Oracle 11g ...

  4. DbWrench002--建模以及数据正向工程和反向工程的具体操作

    DbWrench--建模以及数据正向工程和反向工程 参考博客:https://my.oschina.net/u/3459265/blog/1611999 一.数据正向工程 在建模工作中画好的表与表之间 ...

  5. 正向工程configuration配置连接

    在执行正向工程的时候需要用到这个关键词里面的configure();方法, 这个方法有好几个重构, 都是参数不一样的, 也可以空着不写, 不写的话就会默认去找hibernate.cfg.xml这个文件 ...

  6. Powerdesigner打开工程提示打印错误 解决方法

    在使用PowerDesigner打开工程时, 提示打印错误的问题,具体错误信息提示如下: 在您可以执行与打印机有关的任务(例如页面设置或打印一个文档)之前,您必须已经安装打印机.您想现在安装打印机么? ...

  7. Rose如何由模型生成代码(正向工程)

    原创 正向工程: 选中要转换的模型. 单击 tools>Java/J2EE > Syntax Check 来检查目标代码是否符合规范,比如命名错误. 察看rose log窗口(下方)察看检 ...

  8. hibernate正向工程生成数据库

    hibernate正向工程生成数据库 hibernate.cfg.xml ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 2 ...

  9. 懒要懒到底,能自动的就不要手动,Hibernate正向工程完成Oracle数据库到MySql数据库转换(含字段转换、注释)

    需求描述 需求是这样的:因为我们目前的一个老项目是Oracle数据库的,这个库呢,数据库是没有注释的,而且字段名和表名都是大写风格,比如 在代码层面的po呢,以前也是没有任何注释的,但是经过这些年,大 ...

随机推荐

  1. Cygwin安装时,选择163的源后出错:Unable to get setup.ini from <http://mirrors.163.com/cygwin/>

    [问题] 折腾: [记录]Cygwin下把make从v3.82换成v3.81 期间,选择了163的源,结果出错: Cygwin Setup Unable to get setup.ini from & ...

  2. 通过 PHP 判断用户的设备是否是移动设备

    <?php function isMobile() { // 如果有HTTP_X_WAP_PROFILE则一定是移动设备 if (isset ($_SERVER['HTTP_X_WAP_PROF ...

  3. HTML5学习(八)----Web存储

    参考地址:http://www.w3school.com.cn/html5/html_5_webstorage.asp 在客户端存储数据 HTML5 提供了两种在客户端存储数据的新方法: localS ...

  4. 1003. Parity(并查集)

    1003 看篇国家论文 <从<parity>的解法谈程序优化> 对于区间i,j 如果用sum[i],sum[j]来表示到i的1的个数的奇偶性 那么仔细想下 sum[i-1] 若 ...

  5. 嵌入式Linux系统运行流程图

    /************************************************************************ * 嵌入式Linux系统运行流程图 * 说明: * ...

  6. Mysql加密方式

    MySQL数据库的认证密码有两种方式, MySQL 4.1版本之前是MySQL323加密,MySQL 4.1和之后的版本都是MySQLSHA1加密, MySQL数据库中自带Old_Password(s ...

  7. CVTE公司面经

    1.先是网上测评,通过后通知你参加一面. 2.关于一面:一共进行了10分钟左右,三四个人一起面,没有问什么技术. 一共问了3个问题:a.你为什么选择我们公司的这个职位.我答的大概意思是本科研究生期间, ...

  8. matlab mex入门简介

    mex 的目的 通过C/C++语言编写代码,在Matlab中将其编译成mex文件主要可以做以下几方面的事情: 1.加快程序的执行速度. Matlab在for上如老牛拉车的速度确实让人抓狂. 2.将Ma ...

  9. longblogV1.0——我的静态博客发布系统

    longblogV1.0——我的静态博客发布系统 环境依赖: python3-markdown 作者:IT小小龙个人主页:http://long_python.gitcafe.com/电子邮箱:lon ...

  10. [原创]使用squish打包与混淆cocos2d-x的lua脚本

    squish是一个开源的用于打包lua脚本的小工具,它的主要功能是将多个lua文件整合成一个文件,并在此基础上做压缩和混淆等处理,混淆和压缩后的代码可以直接被执行而不需要先做解压还原等操作. 它的gi ...