在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中去掉即可。
相关文章推荐
- 关于PowerDesigner中,创建ACCESS数据库的一些问题
- mssql:t-sql;创建表;给表添加约束;使用变量;事务,索引,视图;存储过程;触发器trigger;播放器http://www.smartgz.com/blog/Article/956.asp
- 解决PowerDesigner 创建表Code和Name同步的问题
- oracle创建触发器的脚本在sqlplus中执行不了问题的解决
- 有关firefox下js在table中动态创建form元素无法传值问题
- 有关引用的创建控件错误问题
- 不同服务器之间的数据库创建触发器会遇到的一些问题
- 有关firefox和chrome下js动态创建form元素无法传值的问题
- oracle自增auto_increment与oracle 创建触发器是非法的 ORA-04098: trigger 'USER_TRIGGER'is invalid and failed re-v
- 解决在Oracle数据库中使用hibernate生成表不能正确创建表的有关问题
- Oracle数据库中有关触发器问题
- 建行个人卡不能委付trigger|itpub版主已经版主解决||触发器不能读它问题|
- 有关linux下php创建目录权限问题
- 解决PowerDesigner中DBMS设置的问题-创建物理模型时DBMS选项为空
- 学习mysql(6),触发器的创建。trigger
- 触发器Trigger的创建
- powerdesigner中去掉Oracle生成的SQL创建语句中的双引号后再次生成sql的脚本导入数据库中产生的异常问题
- 解决PowerDesigner中DBMS设置的问题-创建物理模型时DBMS选项为空
- SQLServer 触发器 同时插入多条记录有关问题
- 用phpMyadmin给MySQL数据表创建触发器遇到的问题