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

ylhyh 2004-12-03 05:22:01
我想在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

...全文
2000 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
liubiqu 2010-06-10
  • 打赏
  • 举报
回复
这个是因为在PD的脚本里定义了触发器的头部输入文件。你可以在database->edit current dbms... 里修改 script/sql/file中的trgHeader中去掉即可。
ylhyh 2004-12-07
  • 打赏
  • 举报
回复
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;
/
qiubolecn 2004-12-06
  • 打赏
  • 举报
回复
写trigger的脚本时,必须包含所有的代码,比如
create trigger ... 这一些。

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

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

这时会打开一个DBMS PROPERTIES窗体,在第二个页面
trigger templates中就可以增加属于你自己的模板。
ylhyh 2004-12-06
  • 打赏
  • 举报
回复
有没有人遇到相同的问题?
ylhyh 2004-12-04
  • 打赏
  • 举报
回复
是啊,我也是通过Database ---> Generate Triggers & Procedure...来生成的但是却只包括Procedure的代码而不包括Triggers的代码。
wangybyangxr 2004-12-03
  • 打赏
  • 举报
回复
Sorry,还未写完,选项你都选了吗?
wangybyangxr 2004-12-03
  • 打赏
  • 举报
回复
Database ---> Generate Triggers & Procedure...

2,596

社区成员

发帖
与我相关
我的任务
社区描述
Sybase相关技术讨论区
社区管理员
  • Sybase社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧