惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - wljcan

重新开始 - wljcan FMEFB开始上传 代码实现的事件响应 UIAlertView的使用方法 开始新的学习历程--ios开发 nod32 制作的手机电子书UMD文件编辑器 关于IOC 精彩的讨论《数据库时代的终结 》 Oracle开发中,关于查询的一个问题 使用NHibernate时需要考虑的另一个问题 关于crystal report和NHibernate应用的一个问题 使用NHibernate时,如何提高访问Oracle数据库(ODP.net)的性能 在Google 上搜书的方法 (转) - wljcan 一个NHibernate的好工具---Query Analyzer 北京公司招聘 .net开发人员 ArrayList中的排序 .net使用Com组件的问题 应用中的安全管理方案
在PowerDesigner中生成SQL脚本时,如何生成备注信息?
wljcan · 2005-03-08 · via 博客园 - wljcan

在留言中,听棠.net提到了一个问题: 在Powerdesigner中生成 SQL时如何生成相关备注信息? 这个问题以前也有很多朋友问过,现在在这里详细阐述一下。

不同版本的PowerDesigner在不同的数据库模型中,生成Sql脚本的方式是不一样的。在PD6.5生成 Oracle脚本时,会自动根据模型中的Comment生成数据库中相关的注释,但是在9.0以上版本好象就比较麻烦。 而不论什么样版本的PD,都不能自动生成Sql server的注释。

要想解决这个问题,也比较简单:直接利用Powerdesigner提供的OLE对象编程。 PD提供多种语言的开发例子,在Sybase\PowerDesigner 10\Ole Automation目录下,在这里就关键地方进行说明:

1、利用OLE打开模型:
    private    StreamWriter SW;
    private PdCommon.Application pd;
    private     PdPDM.Model  model;

    private void cmdOpenModal_Click(object sender, System.EventArgs e)
        {

                    pd = new PdCommon.Application();

            if (pd != null)
            {
                // 打开一个模型
                openFileDialog1.Title="选择模型文件";
                openFileDialog1.Filter="模型文件(*.pdm)|*.pdm";
                if (openFileDialog1.ShowDialog()==DialogResult.Cancel)
                {
                    return;
                }

                            string strFileName=openFileDialog1.FileName;

                                        model = (PdPDM.Model)pd.OpenModel(strFileName,PdCommon.OpenModelFlags.omf_Default);
                if (model == null)
                {

                                MessageBox.Show("不能打开Powerdesigner模型!", "Powerdesigner", MessageBoxButtons.OK, MessageBoxIcon.Error);
                    return;

                                }
                foreach( Control c in  panel1.Controls            )

                                    {
                    c.Enabled=true;
                }

                            }
            else
            {
                MessageBox.Show("不能创建Powerdesigner应用,请检查是否安装或者Powerdeisnger是否注册。 可以可使用 命令注册该对象: pdshell10.exe /RegServer",
                    "Powerdesigner", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

2、生成备注的SQL脚本

       private void BuilderCommentSql()
        {
            openFileDialog1.Title="选择SQL文件文件";
            openFileDialog1.Filter="脚本文件(*.sql)|*.sql";
            openFileDialog1.CheckFileExists=false;
            openFileDialog1.ShowDialog();
            string strSqlFile=openFileDialog1.FileName;

                    if (strSqlFile==null || strSqlFile=="") return;
            FileInfo FI=new FileInfo(strSqlFile);

                    if (!FI.Exists)  //文件不存在
            {
                SW=FI.CreateText();
            }
            else
            {
                SW=new StreamWriter(strSqlFile,false,System.Text.Encoding.GetEncoding("GB2312"));
            }

                    //DialogResult dr =MessageBox.Show("要删除已经有的描述吗》?");
            //处理包
            foreach (PdPDM.Package p in  model.Packages)
            {
                ProcessPakageToMSSQL(p);
            }

                    SW.Close();

            MessageBox.Show("成功生成备注文件");

                   }
3、核心处理函数 (SQL Server)
       private void ProcessPakageToMSSQL(PdPDM.Package pk)
        {

                        //处理包
            foreach (PdPDM.Package p in pk.Packages)
            {
                ProcessPakageToMSSQL(p);
            }

            foreach (PdPDM.Table table in pk.Tables)
            {

                                    foreach(PdPDM.Column cl in table.Columns)
                {
                    string strWriteLine;
                    strWriteLine="exec sp_dropextendedproperty  N'MS_Description',"+
                         "N'user', N'dbo', N'table', N'"+ table.Code +"', " +
                        "N'column', N'" +cl.Code+"'";
                    SW.WriteLine(strWriteLine);
                    SW.WriteLine("go");
                    strWriteLine="exec sp_addextendedproperty N'MS_Description',"+
                        "N'"+cl.Name+"', N'user', N'dbo', N'table', N'"+ table.Code +"', " +
                        "N'column', N'" +cl.Code+"'";

                      SW.WriteLine(strWriteLine);
                    SW.WriteLine("go");

                                }
            }

                    }
  ///ORACLE
        private void ProcessPakageOracle(PdPDM.Package pk)
        {

                                   //处理包
            foreach (PdPDM.Package p in pk.Packages)
            {
                ProcessPakageOracle(p);
            }

            foreach (PdPDM.Table table in pk.Tables)
            {
                string strWriteLine;
                strWriteLine="COMMENT ON TABLE "+table.Code+" IS '"+table.Comment+"';";
                SW.WriteLine(strWriteLine);
                foreach(PdPDM.Column cl in table.Columns)
                {
                    strWriteLine="COMMENT ON COLUMN "+table.Code+"."+cl.Code+" IS '"+cl.Comment+"';";
                    SW.WriteLine(strWriteLine);

                                }
            }

                    }

    }

以上的这种方案虽然能将问题解决,但不是很完美。以前在用PD生成NHibernate配置文件时,使用了PD OO模型中的Object Language, 可以非常方便地在PD中实现Preview功能 。 但是在DBMS模型中,开放的对象和支持的语法都比较少,不能实现这种需求(感兴趣的话可以看一下 %Tabldefn%,它是系统变量,无法配置。)