zoukankan      html  css  js  c++  java
  • PowerDesigner列名、注释内容互换

    资料来源:PowerDesigner列名、注释内容互换

    文中一共提供了2种操作的代码。

    (1)将Name中的字符COPY至Comment中

    (2)将Comment中的字符COPY至Name中

    使用方法是,在PowerDesigner中PowerDesigner->Tools->Execute Commands->Edit/Run Scripts(Ctrl Shift X),然后将下面的脚本粘贴进去,并运行,即可。

    下面贴出代码

    1将Name中的字符COPY至Comment中

    有两种写法

    代码一:将Name中的字符COPY至Comment中
    '******************************************************************************
    '* File:     name2comment.vbs
    '* Purpose:   Database generation cannot use object names anymore
    '         in version 7 and above.
    '         It always uses the object codes.
    '
    '         In case the object codes are not aligned with your
    '         object names in your model, this script will copy
    '         the object Name onto the object Comment for
    '         the Tables and Columns.
    '
    '* Title:
    '* Version:   1.0
    '* Company:   Sybase Inc.
    '******************************************************************************
    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
    
    ' This routine copy name into comment for each table, each column and each view
    ' of the current folder
    Private sub ProcessFolder(folder)
      Dim Tab 'running   table
      for each Tab in folder.tables
        if not tab.isShortcut then
          tab.comment = tab.name
          Dim col ' running column
          for each col in tab.columns
            col.comment= col.name
          next
        end if
      next
    
      Dim view 'running view
      for each view in folder.Views
        if not view.isShortcut then
          view.comment = view.name
        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
    代码二:将Name中的字符COPY至Comment中(优化)
    '把pd中那么name想自动添加到comment里面
    '如果comment为空,则填入name;如果不为空,则保留不变,这样可以避免已有的注释丢失.
    
    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
    
    ' This routine copy name into comment for each table, each column and each view
    ' of the current folder
    Private sub ProcessFolder(folder)
      Dim Tab 'running   table
      for each Tab in folder.tables
        if not tab.isShortcut then
             if trim(tab.comment)="" then '如果有表的注释,则不改变它.如果没有表注释.则把name添加到注释里面.
           tab.comment = tab.name
             end if
          Dim col ' running column
          for each col in tab.columns
            if trim(col.comment)="" then '如果col的comment为空,则填入name,如果已有注释,则不添加;这样可以避免已有注释丢失.
             col.comment= col.name
            end if
          next
        end if
      next
    
      Dim view 'running view
      for each view in folder.Views
        if not view.isShortcut and trim(view.comment)="" then
          view.comment = view.name
        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

    2将Comment中的字符COPY至Name中

    代码二:将Comment中的字符COPY至Name中
    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
  • 相关阅读:
    HBuilder手机Iphone运行提示“未受信用的企业级开发者”
    在阿里云服务器ubuntu14.04运行netcore
    微信图片上传
    一段sql的优化
    设计模式之单例模式(Singleton)
    PDF.NET+EasyUI实现只更新修改的字段
    操作系统进程调度之分时,优先,分时优先
    2020最新Servlet+form表单实现文件上传(图片)
    Php7+Mysql8实现简单的网页聊天室功能
    JavaSwing+Mysql实现简单的登录界面+用户是否存在验证
  • 原文地址:https://www.cnblogs.com/bailiyi/p/3498566.html
Copyright © 2011-2022 走看看