Sybase PowerDesigner16.5反向工程PostgreSQL12.6数据库

一、基本环境

  1. Sybase PowerDesigner版本号:16.5.0.3982
  2. JDK版本号:jdk-8u201-windows-i586 下载地址
  3. PostgreSQL版本号:12.6
  4. postgressql jdbc驱动jar包:postgresql-8.1-415.jdbc3.jar 下载地址

二、打开PowerDesigner新建一个空白物理数据模型

        点击PowerDesigner菜单栏“File” -> “New Model” -> “Model types”

        选择左侧“PhysicalDataModel”,在“Model name”输入新建模型的名称,在“DBMS”选择数据库类型,点击“确定”完成新建。

三、配置连接数据源

        点击PowerDesigner菜单栏“Database” ->configure connections->connection profiles->add data source

 

 

四、让PDM图形列表显示name和code等需要的信息

        点击菜单”TOOLS” —〉显示参数设置(DISPLAY PREFERENCES) , 在弹出来的框中选中Content—〉Table —> 点右下角那个Advanced 按钮 —> 在弹出的框中选中 Columns —>点ListColumns右边的按钮 —> 在弹出的框中找到Code 和 Name ,在它后面的小框中打上勾

五、进行反向工程

        点击“Database”->"Update Model from  Database",弹出窗口“Database Reverse Engineering Options”

 

 

六、PowerDesigner pdm name和comment列显示互转的方法

        PowerDesigner不支持显示comment备注列,所以很多时候我们的pdm中的table是name和comment用一样的中文名称,而code用英文名称。

        但是在用sql或数据库转过来的pdm name和code都是英文字段名,这时候只有把comment转成name列才能显示中文。

打开PowerDesigner 运行命令窗口

 

Option   Explicit   
ValidationMode   =   True   
InteractiveMode   =   im_Batch  
  
Dim   mdl   '   the   current   model  
  
'   get   the   current   active   model   
Set   mdl   =   ActiveModel   
If   (mdl   Is   Nothing)   Then   
      MsgBox   "There   is   no   current   Model "   
ElseIf   Not   mdl.IsKindOf(PdPDM.cls_Model)   Then   
      MsgBox   "The   current   model   is   not   an   Physical   Data   model. "   
Else   
      ProcessFolder   mdl   
End   If  
  
Private   sub   ProcessFolder(folder)   
On Error Resume Next  
      Dim   Tab   'running     table   
      for   each   Tab   in   folder.tables   
            if   not   tab.isShortcut   then   
                  tab.name   =   tab.comment  
                  Dim   col   '   running   column   
                  for   each   col   in   tab.columns   
                  if col.comment="" then  
                  else  
                        col.name=   col.comment   
                  end if  
                  next   
            end   if   
      next  
  
      Dim   view   'running   view   
      for   each   view   in   folder.Views   
            if   not   view.isShortcut   then   
                  view.name   =   view.comment   
            end   if   
      next  
  
      '   go   into   the   sub-packages   
      Dim   f   '   running   folder   
      For   Each   f   In   folder.Packages   
            if   not   f.IsShortcut   then   
                  ProcessFolder   f   
            end   if   
      Next   
end   sub

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值