您的位置:首页 > 其它

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

2017-01-23 09:33 567 查看

在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中去掉即可。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐