PowerDesigner导入sql脚本(同时保证注释不丢失及name copy comment)

本文介绍使用PowerDesigner通过导入SQL脚本快速维护数据库模型的方法,包括调整SQL格式以匹配PowerDesigner规范,以及使用脚本将表和字段的注释转换为名称,提升模型的可读性和维护效率。

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

写在前面

一个好的数据库建模,不但可以让人直观的理解模型,充分的利用数据库技术,优化数据库的设计,而且还可以让新员工快速的熟悉数据库表结构与业务之间的关系.无奈的是随着开发过程中,数据库表结构字段的增删以及关联关系的变动给数据库模型带来维护上的巨大工作量.现为了维护上的简单,介绍一种快速维护数据库模型的方式,PowerDesigner导入sql脚本的方式.

正文

  首先,是一份写好的sql脚本

  然后,上图

1.依次点击File->Reverse Engineer->Database...

2.弹出弹窗对模型进行命名,同时在DBMS下拉选择框中需要选择自己对应的数据库类型,点击确定

3.新的弹窗,选中Using script files,再点击红圈中,选中你的sql脚本位置,点击确定

4,结果图

ok,导入sql脚本成功,并且生成了模型

 

补充

1.注释丢失.由于Sql转模型的时候,会因为格式不符合PowerDesigner的标准或者数据库类型与PowerDesigner的类型对应不上等杂七杂八的原因会造成注释的丢失,这是我们需要将sql的格式改成符合PowerDesigner的规范,重新进行导入就行了.

修改前: `ct_no` varchar(30) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '反恐舱单编号;如ams编号'

修改后:`ct_no` varchar(30)  NULL DEFAULT NULL COMMENT '反恐舱单编号;如ams编号'

 

修改前:`create_time` datetime(0) NULL DEFAULT NULL COMMENT '创建时间'

修改后:`create_time` datetime NULL DEFAULT NULL COMMENT '创建时间'

 

结论:可以适当的修改表结构使得PowerDesigner更加适合导入sql,从而显示中文注释

2.如何让Name里面的值显示的是comment里面的值

在使用REVERSE ENGINEER从数据库反向生成PDM的时候,PDM中的表的NAME和CODE事实上都是CODE,为了把NAME替换为数据库中Table或Column的中文Comment,可以使用以下脚本:

在PowerDesigner中使用方法为:

PowerDesigner->Tools->Execute Commands->Edit/Run Scripts

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

结果图如下:

3.有时我们生成的物理模型所包含的表结构太多了,这是对于我们来说查看某一个表结构会显得格外困难,这里介绍一种PowerDesigner里查找特定的表.

3.1.crtl+f查找,在code处输入你要查找的表名,然后点击“find now".

3.2.右击找到的表,点击”find in diagram"即可.

 

参考链接:https://www.cnblogs.com/xiaotao726/p/6841811.html

参考链接:https://www.cnblogs.com/fjrgg/p/9682804.html

### 如何定位或找回丢失SQL 脚本 当涉及到 SQL 脚本丢失问题时,可以采取多种方法来尝试恢复或重新获取这些脚本。以下是几种可能的方法: #### 方法一:检查备份文件 如果存在定期备份机制,则可以从最近的备份中检索到所需的 SQL 脚本。通常情况下,企业环境中的数据库都会配置自动化的备份策略[^1]。 ```bash # 假设备份存储在一个特定目录下 ls /path/to/backup/directory/ cat backup_file.sql | grep "specific_table_name" ``` 通过上述命令可快速查看是否存在目标表结构定义的相关语句。 --- #### 方法二:利用版本控制系统 对于开发团队而言,SQL 文件往往会被纳入版本控制工具(如 Git 或 SVN)。因此可以通过查询历史记录找到对应的脚本内容[^2]。 ```bash git log -- path_to_sql_script.sql git checkout commit_hash -- path_to_sql_script.sql ``` 这里展示了如何基于某个提交哈希值检出指定版本下的 SQL 文件实例。 --- #### 方法三:借助 PowerDesigner 的功能特性 假如原始 SQL 是由 PowerDesigner 导入导出而来,在某些场景下即使注释部分遗失也可以依据其内部逻辑重建完整的对象描述信息[^3]。具体做法如下: - 修改字段属性使其更贴近标准模板; - 再次执行导入流程并开启选项允许 Name Copy Comment 功能支持。 示例代码片段展示了一个典型列定义调整过程: ```sql ALTER TABLE example_table MODIFY COLUMN ct_no VARCHAR(30) CHARSET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '反恐舱单编号; 如 ams 编号'; ``` 注意以上语法需根据实际使用的 RDBMS 类型做适当转换处理。 --- #### 方法四:询问相关人员或其他资源渠道 最后一种方式就是联系项目组成员或者其他熟悉该系统的同事寻求帮助。他们或许能够提供额外线索甚至直接分享最新版文档资料链接地址等有用情报源。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值