PDM后续处理-驼峰规则、清除约束、外键改名

Option   Explicit

ValidationMode   =   True

InteractiveMode =   im_Batch

Dim   mdl   ‘当前model

‘获取当前活动model

Set   mdl   =   ActiveModel

If   (mdl   Is   Nothing)   Then

MsgBox   "There   is   no   current   Model "

ElseIf   Not   mdl.IsKindOf(PdPDM.cls_Model)   Then ‘如果是处理pdm,这里换成PdPDM.cls_Model

MsgBox   "The   current   model   is   not   an   Physical   Data   model. "

Else

ProcessFolder   mdl

End   If

Private   sub   ProcessFolder(folder)

dim tab

‘11111111111111111111111111111111111111111111111111111111111111111

for   each   tab   in  folder.tables

if   not   tab.isShortcut   then

‘处理每个实体或类的Name和Code

‘先处理表名

Dim code

code = tab.code

code=ManageNameFormat code

tab.code=code

tab.name=code

‘再处理每个字段的名称

dim col

for   each   col   in   tab.columns

Dim acode

acode = col.code

acode=ManageNameFormat acode

col.code=acode

col.name=acode

col.ServerCheckExpression=""  ‘清除每个字段正则表达式约束

col.ListOfValues =""  ‘清除枚举项约束

col.lowvalue="" ‘清除最大值约束

col.highvalue="" ‘最小值约束

next

end  if

next

‘222222222222222222222222222222222222222222222222222222222222222222222222222

‘更改特定外键名称

for   each   ref   in  folder.references

if   not   ref.isShortcut     then

‘根据子表和主表名称更改外键字段名称,将该外键字段名称直接改为该关系名,以子表-主表方式判断

‘根据单表也可以设置

if  lcase(ref.parenttable.name)=lcase("ExVersion")   or  lcase(ref.parenttable.name)=lcase("Ex_Version")   or _

(lcase(ref.childtable.name)=lcase("GM_Arc") and lcase(ref.parenttable.name)=lcase("Point" ))  or _

(lcase(ref.childtable.name)=lcase("GM_Geodesic") and lcase(ref.parenttable.name)=lcase("Point") )  then

dim col

for each col in ref.childtable.columns  ‘不用遍历寻找对应table对象,直接用ref.childtable就能操作,比以前更智能

if lcase(col.name)=  lcase(ref.ForeignKeyColumnList) then

output ref.childtable.name+"."+ref.ForeignKeyColumnList+ "<--------------->"+ ref.childtable.name+"."+ref.name

col.name=ref.name

col.code=col.name

end if

next

end if

end  if

next

‘////////////////////////////////////////////////////////////////////////////////////

‘递归遍历子文件夹

Dim   f   ‘子文件夹

For   Each   f   In   folder.Packages

if   not   f.IsShortcut   then

ProcessFolder   f

end   if

Next

end   sub

‘函数将输入的低驼峰字符串整理成_符分割的字符串

Function ManageNameFormat (code as string) as string

Dim i

i=2

Do While i < len(code)

If mid(code,i,1)=ucase(mid(code,i,1)) and mid(code,i-1,1)=lcase(mid(code,i-1,1)) and mid(code,i-1,1)<>"_" and mid(code,i,1)<>"_" and mid(code,i-1,1)<>"2" and mid(code,i,1)<>"2" Then ‘连续大写字母不用加_

code = left(code,i-1) + "_" + mid(code,i)

i =i+ 1

End If

i =i+ 1

Loop

ManageNameFormat=code

End Function

时间: 2024-11-06 04:52:55

PDM后续处理-驼峰规则、清除约束、外键改名的相关文章

PowerDesigner 12小技巧-pd小技巧-pd工具栏不见了-pd修改外键命名规则-pd添加外键

PowerDesigner 12小技巧-pd小技巧-pd工具栏不见了-pd修改外键命名规则-pd添加外键 1. 附加:工具栏不见了 调色板(Palette)快捷工具栏不见了PowerDesigner 快捷工具栏 palette 不见了,怎么重新打开,找回来呢 上网搜索了一下"powerdesigner 图形工具栏",找到了找回PowerDesigner工具栏palette的方法Tools(工具栏)customsize toolbars(自定义工具栏)palette(调色板)勾选 2.

MySQL 数据类型和约束(外键是重点&#128580;)

数据类型 1. 数字(默认都是由符号,宽度表示的是显示宽度,与存储无关).tinyint 括号里指定宽度 七位2进制数最大数就是2**7 -1=127 最小是-128 验证: create tabel t1(id tinyint) create tabe t2(id int) 浮点数 float double decimal 测试 create table t2(salary float) float(6,2) 第一参数,代表宽度. 第二个参数代表小数点后面的位数. 2.字符串类型 char 与

总结: MySQL(基础,字段约束,索引,外键,存储过程,事务)操作语法

1. 显示数据库列表 show databases; # 查看当前所有数据库 show databases \G   #以行的方式显示 2. 在命令行中,执行sql语句 mysql -e 'show databases' -uroot -p123456 mysqlshow -uroot -p123456 # 不常用,记住上面那个就行了 3.创建数据库语法 create database 数据库名; 例如: create database `HA-test`; 4. 切换数据库 use HA-te

Sql Server 主键 外键约束

主键约束 表通常具有包含唯一标识表中每一行的值的一列或一组列. 这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性. 由于主键约束可保证数据的唯一性,因此经常对标识列定义这种约束. 如果为表指定了主键约束, 数据库引擎 将通过为主键列自动创建唯一索引来强制数据的唯一性. 当在查询中使用主键时,此索引还允许对数据进行快速访问. 如果对多列定义了主键约束,则一列中的值可能会重复,但来自主键约束定义中所有列的值的任何组合必须唯一. 如下图所示, Purchasing.ProductVend

(二)表的连接与外键约束

外键约束和表连接 [建立表的关系] 1.额外建立一张表描述两个表之间的关系,存储两张需要连接的表的主键对应关系. 2.利用外键约束 外键:一张表的某个字段引用着另一张表的主键,在数据多的表中多一个字段,存储对应的另一张表的主键. 外键的创建: CONSTRAINT <外键名前缀> FOREIGN KEY <表中的键名> REFERENCES <引用的表名> (<引用的字段>); 级联: 删除了一部分,有对应关系的另一个部分会被删除. [表连接] 假如有t_s

主键和外键约束(主表与从表)

通过上一篇随笔,笔者了解到,实体完整性是通过主键约束实现的,而参照完整性是通过外键约束实现的,两者都是为了保证数据的完整性和一致性. 主键约束比较好理解,就是主键值不能为空且不重复,已经强调好多次,所以这里重点记录对外键约束的学习. 主表与从表 若同一个数据库中,B表的外键与A表的主键相对应,则A表为主表,B表为从表. 假设学生表(学号,姓名,性别,专业号),专业表(专业号,专业名称),则学生表中的专业号为学生表的外键,其与专业表中"专业号"属性相关联,因此,专业表为主表,学生表为从表

Oracle系统表外键的更名

正在看的ORACLE教程是:Oracle系统表外键的更名. Oracle中表的外键是保证系统参照完整性的手段,而参照完整性是指分布在两个表中的列所满足的具有主从性质的约束关系.外键涉及到两个表,其中一个称之为父项表,另一个称之为子项表. 父项表(parent table)是参照约束的基础,即通过检查这张表的有效数据情况来判断约束是否成立,它是参照约束的条件,影响约束,而不受约束的任何影响. 子项表(child table)是参照约束的对象,当其发生变化,如有新数据输入时,通过比较父项表中的有效数

20150102--Mysql外键+增删改查-02

外键 外键:外面的键,前表中的某个字段与另外的表中的字段(主键)有一个对应的关系 外键关键字:foreign key,也是一种索引. 创建外键 外键和主键有点类似,但是不一样. 1. 在所有的字段之后,指定对应的外键. foreign key(字段名) references 表名(字段) 外键约束 外键的作用是用来维护两张表之间的关系,关系是用来限制表操作的. 父表(主表):被外键指向的表叫做主表 子表(从表):存在外键字段的表叫子表 1. 限制子表数据的插入:子表中的外键字段的值必须事先已经在

Oracle外键级联删除和级联更新

1 级联删除 Oracle在外键的删除上有NO ACTION(类似RESTRICT).CASCADE和SET NULL三种行为. 下面以学生-班级为例说明不同情况下的外键删除,学生属于班级,班级的主键是学生的外键. -- 班级表 CRATE TABLE TB_CLASS ( ID NUMBER NOT NULL, --班级主键 NAME VARCHAR2(50), --班级名称 CONSTRAINT PK_TB_CLASS PRIMARY KEY (ID) ); -- 学生表 CREATE TA