在PowerDesigner中创建触发器(Trigger)的有关问题

在PowerDesigner中创建触发器(Trigger)的有关问题

signer中创建触发器(Trigger)的问题
我想在PowerDesigner9.5(下称PD)中创建一个Trigger对象,可以像表一样在生成数据库脚本时生成该Trigger的创建代码,可我在PD中创建一个Trigger Item,然后把代码写在的该Trigger Item的Definition页,在执行Generate Triggers&Procedures菜单项的功能生成该Trigger及Procedure的脚本时,脚本中却不包括该Trigger的生成脚本,请高手赐教……

Trigger templates是用来干什么的?我试着创建一个templates,然后在该templates的trigger item页却不能添加我前面建立的trigger item


------最佳解决方案--------------------
写trigger的脚本时,必须包含所有的代码,比如
create trigger ... 这一些。

你也可以在definition的最左边选择一个模板。

如果你想增加一个属于自己的模板,请通过以下方法
DataBase\Edit Current DBMS
或者
Tools\Resource\DBMS...中选择你想修改的数据库。

这时会打开一个DBMS PROPERTIES窗体,在第二个页面
trigger templates中就可以增加属于你自己的模板。

------其他解决方案--------------------
Database ---> Generate Triggers & Procedure...
------其他解决方案--------------------
Sorry,还未写完,选项你都选了吗?
------其他解决方案--------------------
是啊,我也是通过Database ---> Generate Triggers & Procedure...来生成的但是却只包括Procedure的代码而不包括Triggers的代码。

------其他解决方案--------------------
有没有人遇到相同的问题?
------其他解决方案--------------------
qiubolecn(来自差生市) ,我好像把Trigger代码放错地方了,我是在我Workspace下的Modal里右键New了一个Trigger Template Item,并没有直接在Table属性的Triggers页面中增加,我在Table的Triggers页面中增加就可以了。但在生成SP及Trigger代码时会生成如下package的定义,可我并没有在Modal中建立Package,这是为何?

-- Integrity package declaration
create or replace package IntegrityPackage AS
 procedure InitNestLevel;
 function GetNestLevel return number;
 procedure NextNestLevel;
 procedure PreviousNestLevel;
 end IntegrityPackage;
/

-- Integrity package definition
create or replace package body IntegrityPackage AS
 NestLevel number;

-- Procedure to initialize the trigger nest level
 procedure InitNestLevel is
 begin
 NestLevel := 0;
 end;


-- Function to return the trigger nest level
 function GetNestLevel return number is
 begin
 if NestLevel is null then
     NestLevel := 0;
 end if;
 return(NestLevel);
 end;

-- Procedure to increase the trigger nest level
 procedure NextNestLevel is
 begin
 if NestLevel is null then
     NestLevel := 0;
 end if;
 NestLevel := NestLevel + 1;
 end;

-- Procedure to decrease the trigger nest level
 procedure PreviousNestLevel is
 begin
 NestLevel := NestLevel - 1;
 end;

 end IntegrityPackage;
/
------其他解决方案--------------------
这个是因为在PD的脚本里定义了触发器的头部输入文件。你可以在database->edit current dbms... 里修改 script/sql/file中的trgHeader中去掉即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值