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

本文详细介绍了如何在Sybase PowerDesigner 16.5.0.3982中创建物理数据模型,配置连接数据源,设置显示参数以展示中文注释,并演示了如何使用代码实现pdmname和comment列的互转,以解决中文显示问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、基本环境

  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

### 使用 PowerDesigner 16.5 进行反向工程生成类图 #### 创建新模型 为了启动反向工程项目,在 PowerDesigner 中需访问菜单栏并选择 `File` -> `New Model` -> `Model types` [^2]。在此过程中,应选择适合于目标数据库类型的物理数据模型 (PDM),概念数据模型 (CDM),或是逻辑数据模型 (LDM)[^3]。 #### 配置数据库连接 进入相应的建模环境之后,下一步是设置到源数据库的链接。这涉及到配置代理服务的连接参数,确保能够顺利建立通信渠道。完成配置后应当点击测试按钮来确认连通性正常,并验证所输入的数据库用户名和密码无误。 #### 执行反向工程过程 当上述准备工作就绪以后,即可着手执行实际的反向工程操作。通常情况下,此功能位于工具条或上下文菜单之中;用户只需按照提示逐步选取待分析的对象以及指定输出选项即可实现自动化处理[^1]。 #### 完成后的调整优化 一旦反向工程顺利完成,得到的结果可能还需要进一步的手动编辑和完善。比如调整实体间的关系表示方式、补充必要的注释说明等动作都是常见做法。此外,对于某些特定需求而言,或许还要考虑转换为其他形式的数据结构视图以便更好地满足项目要求。 ```sql -- 示例SQL语句用于展示如何查询表信息(假设使用的是PostgreSQL) SELECT table_name, column_name, data_type FROM information_schema.columns WHERE table_schema='public'; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值