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

标签 postgresql

假设我有两个表,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/

相关文章:

regexp_matches 函数没有给出任何结果

sql - SQL 中 'INTERVAL HOUR TO MINUTE' 数据类型聚合函数的精度

c - 在Postgresql扩展C中获取用户定义的类型OID

ms-access - 我可以将 MS Access 应用程序链接到 Linux 服务器上的 Postgresql 吗?我可以/应该使用 ODBC 吗?

sql - 从表中编写查询的问题

sql - 不区分大小写的重复 SQL

postgresql - 选择查询,用于从内部查询的记录中选择列。其中内部查询和外部查询具有不同的列

php - Heroku 应用程序中保存的图像没有显示?

sql - Rails 控制台 : update column values with trimmed values

python - 如何将 numpy 数组转换为 postgresql 列表