trigger

在同一个表上建三个trigger
ALTER trigger q before update of id
order 1 on DBA.table
for each row  
begin
  insert into a(a,
    b,c) values(\'update\',
    oldnewname.id,newname.id)
end

ALTER trigger c before delete order 1 on
DBA.table
referencing old as oldname
for each row  
begin
  
  insert into a(a,
    b,c) values(\'delete\',\'\',
    oldname.id)
end

ALTER trigger b before insert order 1 on
DBA.table
referencing new as newname
for each row  
begin  
  insert into a(a,
    b,c) values(\'insert\',
    newname.id,\'\')
end
end
执行结果只有两条
a           b       c
delete   123  
insert             321

为什么update 的不执行?太不公平了

posted on 2006-02-08 18:38 青蛙學堂 阅读(544) 评论(2)  编辑 收藏 引用 所属分类: 數據庫

评论

# re: trigger 2006-02-08 18:41 peng

请问trigger能否触发修改另一个用户的数据表?
我对该用户有权限,
在 sc 和 dayend两个用户下有table domain( char(5) , char(5) ),
1.create or replace trigger sc_domain
after insert on domain
for each row
begin
insert into domain values('1234' ,'1234' );
end;

成功
2。
create or replace trigger sc_domain
after insert on domain
for each row
begin
insert into dayend.domain values('1234' ,'1234' );
end;

show errors :2/1 PLS-00201: identifier 'DOMAIN' must be declared
2/1 PL/SQL: SQL Statement ignored

3. sc 用户登陆 sqlplus>insert into dayend.domain values('1234' , '1234' )
成功!

如果你在执行
3. sc 用户登陆 sqlplus>insert into dayend.domain values('1234' , '1234' )
成功!
之前运行set role none;之后如果再运行你的3,如果正常,那么在trigger中也就可以正常了。

你需要:
connect to dayend and grant insert on domain to sc;



  回复  更多评论   

# re: trigger 2006-02-08 18:43 peng

CREATE TRIGGER
名称
CREATE TRIGGER — 创建一个新触发器

CREATE TRIGGER name { BEFORE | AFTER } { event [OR ...] }
ON table FOR EACH { ROW | STATEMENT }
EXECUTE PROCEDURE ER">funcBLE> ( arguments )

输入
name
触发器名称.
table
表名称.
event
INSERT,DELETE 或 UPDATE 之一.
funcname
一个用户提供的函数.
输出
CREATE
如果触发器成功创建,返回此信息.
描述
CREATE TRIGGER 将向现有数据库中增加一个新的触发器.触发器将与表 table 相联并且将执行声明的函数 funcname.

触发器可以声明为在对记录进行操作之前(在检查约束之前和 INSERT,UPDATE 或 DELETE 执行前)或之后(在检查约束之后和完成了 INSERT,UPDATE 或 DELETE 操作)触发.如果触发器在事件之前,触发器可能略过当前记录的操作或改变被插入的(当前)记录(只对 INSERT 和 UPDATE 操作有效).如果触发器在事件之后,所有更改,包括最后的插入,更新或删除对触发器都是"可见"的.

请参考 PostgreSQL 程序员手册 中SPI 和触发器章节获取更多信息.

注意
CREATE TRIGGER 是一个 Postgres 语言扩展.

只有表所有者可以就此表创建一个触发器.

在当前的版本(v6.5),STATEMENT 触发器还没有实现.

请参考 DROP TRIGGER 获取如何删除触发器的信息.

用法
在插入或更新表 films 之前检查一下声明的分销商代码是否存在于 distributors 表中:

CREATE TRIGGER if_dist_exists
BEFORE INSERT OR UPDATE ON films FOR EACH ROW
EXECUTE PROCEDURE check_primary_key ('did', 'distributors', 'did');

在删除或更新一个分销商的内容之前,将所有记录移到表 films 中(译注:好象与例子意义不同):

CREATE TRIGGER if_film_exists
BEFORE DELETE OR UPDATE ON distributors FOR EACH ROW
EXECUTE PROCEDURE check_foreign_key (1, 'CASCADE', 'did', 'films', 'did');

兼容性
SQL92
在 SQL92 里没有 CREATE TRIGGER 语句.

上面第二个例子可以使用一个 FOREIGN KEY 约束实现:

CREATE TABLE distributors (
did DECIMAL(3),
name VARCHAR(40),
CONSTRAINT if_film_exists
FOREIGN KEY(did) REFERENCES films
ON UPDATE CASCADE ON DELETE CASCADE
);

不过,外部键字(foreign keys)在目前的 Postgres 里还没有实现(版本 6.5).(译注:在版本7.0里已经实现了外部键字。)

  回复  更多评论   

只有注册用户登录后才能发表评论。
<2025年1月>
2930311234
567891011
12131415161718
19202122232425
2627282930311
2345678

导航

统计

常用链接

留言簿(8)

随笔分类

随笔档案

收藏夹

青蛙学堂

最新评论

阅读排行榜

评论排行榜