0

0

Powerdesigner自定义DBMS(以derby数据库为例)

php中文网

php中文网

发布时间:2016-06-07 14:59:43

|

2732人浏览过

|

来源于php中文网

原创

Powerdesigner以下简称PD. PD默认支持的DBMS不够用时,我们就需要自己定义了。 以apache derby数据库为例。 1、DBMS的定义文件 PD的DBMS定义文件放在install_dir/Resource Files/DBMS目录下。自定义DBMS的第一步是复制一个现成的DBMS文件,由于derby与Oracle

powerdesigner以下简称pd.
pd默认支持的dbms不够用时,我们就需要自己定义了。
以apache derby数据库为例。
1、dbms的定义文件
pd的dbms定义文件放在install_dir/resource files/dbms目录下。自定义dbms的第一步是复制一个现成的dbms文件,由于derby与oracle相似之处比较多,所以可以选择复制oracle的dbms文件,并重命名为derby.xdb

2、修改描述
用记录本打开derby.xdb,将大概前16行的一些内容做修改。比如code、name等等。我的大体如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

version="1.0" encoding="UTF-8"?>
AppLocale="UTF16" Code="DERBY" Family="DERBY" ID="{04DFD581-D1C0-43E8-B9AE-01951ECAB446}" LastModificationDate="1347972332" Name="Apache Derby" Objects="778" Symbols="0" Type="{4BA9F647-DAB1-11D1-9944-006097355D9B}" signature="XDB_XML" version="15.1.0.2850"?>


xmlns:a="attribute" xmlns:c="collection" xmlns:o="object">

Id="o1">
>
04DFD581-D1C0-43E8-B9AE-01951ECAB446>
>
Apache Derby>
>
DERBY>
>
0>
/>
>
1241243501756>
>test>
> >
>DERBY>

这样修改之后,我们在PD的database菜单里,选择Change Current DBMS时,可以看到下拉选项中,有一项为Apache Derby。

3、修改数据类型转换
由于我们复制的oracle的dmbs文件,与derby中,有些数据类型不一致,所以需要修改。在database菜单里,选择Edit Current DBMS,弹出窗口如下:
Powerdesigner自定义DBMS(以derby数据库为例)
左边是树型结构,点击后右边编辑内容。

修改数据类型时,选择左侧树:Script -> Data Type。
插两句话,讲一下PD数据库切换时字段处理的原理。PD本身定义了一套内部的数据类型,如A%n、N、N%s,%p等,其中:
%n is the length of the data type
%s is the size of the data type
%p is the precision of the data type
当我们由一个DBMS A 换成另一个DBMS B时,PD会首先将A的数据类型转换成PD内部自己定义的数据类型,这个转换的规则这里叫做 A-PD,然后再将内部的数据类型转换成B的数据类型,这里叫做PD-B,通过上面两步转换实现A到B的类型转换。

而A-PD的规则,定义在刚才打开的Data Type节点下的PhysDataType节点,PD-B规则定义在AmcdDataType节点下。
举几个简单的例子:
A、Oracle NUMBER -> Derby BIGINT
首先要查看Oracle的dbms文件,注意是Oracle的,展开到PhysDataType节点下,看到有如下映射
Physical Model | Internal
NUMBER | N
所以,经过A-PD规则后,Oracle的NUMBER类型会转换成PD的内部类型N。
接下来,查看Derby的dbms,打开AmcdDataType节点,找到如下映射:
Internal | Physical Model
N | NUMBER
把上面的NUMBER修改成BIGINT
这样的话,经过PD-B规则,Derby里的字段就会变成BIGINT类型了。

B、Derby BIGINT -> Oracle NUMBER
与上面类型,不过需要查看Derby的PhysDataType和Oracle的AmcdDataType节点。

从上面两个例子基本可以看出来PhysDataType节点用来将数据库类型转换成PD的类型,而AmcdDataType则将PD的内部类型转换成数据库的类型。
另外,可以使用%n,%s,%p实现更精细的转换,且这三个标识也可以完全由数字代替。

4、注释
修改列注释,表格注释在Script\Objects\Table和Script\Objects\Column节点下。其它修改也很类似,如索引、依赖等等。

Script\Sql\Syntax节点下则是一些基本的SQL语法规定,比如注释以–开始,SQL结束符是;等等。

更多详细说明可参考手册:
1、derby:http://db.apache.org/derby/docs/10.9/ref/crefsqlj31068.html
2、PD:http://infocenter.sybase.com/help/topic/com.sybase.infocenter.dc38628.1510/doc/html/rad1232022090125.html
3、使用POWERDESIGNER设计数据库的20条技巧

再说两句其它的,关于PD生成数据库设计文档。
默认的模板生成的文档,有相当多无用的东西,没法儿看。所以我们可以自定义文档模板。在Report -> Report Templates菜单下,在弹出窗口中,点新建,输入名称,然后出现编辑模板的界面,分成左右两块儿,可以把左边一些需要的元素直接拖到右边就OK。报告模板默认放在安装目录\Resource Files\Report Templates\下,我们也可以把这个目录下的文件复制一份,改个名儿,然后在这个基础上修改。

总之一句话,PD很强大。

相关专题

更多
Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

3

2026.01.12

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

97

2026.01.09

c++框架学习教程汇总
c++框架学习教程汇总

本专题整合了c++框架学习教程汇总,阅读专题下面的文章了解更多详细内容。

53

2026.01.09

学python好用的网站推荐
学python好用的网站推荐

本专题整合了python学习教程汇总,阅读专题下面的文章了解更多详细内容。

139

2026.01.09

学python网站汇总
学python网站汇总

本专题整合了学python网站汇总,阅读专题下面的文章了解更多详细内容。

12

2026.01.09

python学习网站
python学习网站

本专题整合了python学习相关推荐汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.09

俄罗斯手机浏览器地址汇总
俄罗斯手机浏览器地址汇总

汇总俄罗斯Yandex手机浏览器官方网址入口,涵盖国际版与俄语版,适配移动端访问,一键直达搜索、地图、新闻等核心服务。

84

2026.01.09

漫蛙稳定版地址大全
漫蛙稳定版地址大全

漫蛙稳定版地址大全汇总最新可用入口,包含漫蛙manwa漫画防走失官网链接,确保用户随时畅读海量正版漫画资源,建议收藏备用,避免因域名变动无法访问。

432

2026.01.09

php学习网站大全
php学习网站大全

精选多个优质PHP入门学习网站,涵盖教程、实战与文档,适合零基础到进阶开发者,助你高效掌握PHP编程。

49

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号