gpt4 book ai didi

postgresql - 触发器在 Postgresql 中插入已删除的行

转载 作者:行者123 更新时间:2023-11-29 14:10:58 26 4
gpt4 key购买 nike

假设我有两个表,ab,它们都有两行 intdate。我想编写一个触发器,当从表 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 中的列被称为 idwhen 而在 B 中它们被称为 aid awhen

您可以通过在 B 中使用串行类型的 PK 来解决 B 的主键问题,或者,如果您只想要 中的一行>B 具有来自 A 的相同 id,当新行插入 A 时,触发器从 B 中删除

关于postgresql - 触发器在 Postgresql 中插入已删除的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30716772/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com