假设我有两个表,a
和 b
,它们都有两行 int
和 date
。我想编写一个触发器,当从表 a
中删除行时,将它们复制到表 b
并将日期更改为当前日期。因此,如果我今天从表 a
中删除带有 13, 2015-01-01
的行,则会插入 13, 2015-06-08
进入表 b
。
关于如何完成这项工作的任何想法?
最佳答案
create or replace function a_adr_tf() returns trigger as $$
begin
insert into b(aid, awhen) values (old.id, now());
return old;
end;
$$ language plpgsql;
create trigger a_adr after delete from a for each row execute procedure a_adr_tf();
请注意,此触发器不会处理表 b
中可能存在的重复主键。我假设 A
中的列被称为 id
和 when
而在 B
中它们被称为 aid
和 awhen
。
您可以通过在 B
中使用串行类型的 PK 来解决 B
的主键问题,或者,如果您只想要 中的一行>B
具有来自 A
的相同 id
,当新行插入 A 时,触发器从
。B
中删除
关于postgresql - 触发器在 Postgresql 中插入已删除的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30716772/