在PowerDesigner中创建触发器(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中去掉即可。