postgresql 的更新类型
Type of update on postgresql
Postgres 的新手和 PL/pgSQL 这里。
我如何着手编写 PL/pgSQL 函数以根据对 postgres 数据库中的 table/record 进行的更新类型(插入、删除等)执行不同的操作。
您似乎在寻找触发器。
在 SQL 中,触发器是在对象上发生特定事件时调用(触发)的过程,例如,当更新、删除或插入 table 时。触发器可以响应许多用例,例如实施业务完整性规则、清理数据、审计、安全......
在 Postgres 中,您应该先定义一个 PL/pgSQL 函数,然后在触发器声明中引用它。
CREATE OR REPLACE FUNCTION my_table_function() RETURNS TRIGGER AS $my_table_trigger$
BEGIN
...
END
$my_table_trigger$ LANGUAGE plpgsql;
CREATE TRIGGER my_table_trigger
AFTER INSERT OR UPDATE OR DELETE ON mytable
FOR EACH ROW EXECUTE PROCEDURE my_table_function();
在触发器代码中,您可以访问一组特殊变量,例如:
NEW
、OLD
: 伪记录包含 new/old 条受查询影响的数据库记录
TG_OP
:触发触发器的操作(INSERT
、UPDATE
、DELETE
、...)
使用这些变量和其他触发器机制,您可以分析或更改正在进行的操作,甚至可以通过引发异常来中止它。
我建议阅读 the CREATE TRIGGER
statement and Trigger Procedure 的 Postgres 文档(最新的文档提供了大量示例)。
Postgres 的新手和 PL/pgSQL 这里。
我如何着手编写 PL/pgSQL 函数以根据对 postgres 数据库中的 table/record 进行的更新类型(插入、删除等)执行不同的操作。
您似乎在寻找触发器。
在 SQL 中,触发器是在对象上发生特定事件时调用(触发)的过程,例如,当更新、删除或插入 table 时。触发器可以响应许多用例,例如实施业务完整性规则、清理数据、审计、安全......
在 Postgres 中,您应该先定义一个 PL/pgSQL 函数,然后在触发器声明中引用它。
CREATE OR REPLACE FUNCTION my_table_function() RETURNS TRIGGER AS $my_table_trigger$
BEGIN
...
END
$my_table_trigger$ LANGUAGE plpgsql;
CREATE TRIGGER my_table_trigger
AFTER INSERT OR UPDATE OR DELETE ON mytable
FOR EACH ROW EXECUTE PROCEDURE my_table_function();
在触发器代码中,您可以访问一组特殊变量,例如:
NEW
、OLD
: 伪记录包含 new/old 条受查询影响的数据库记录TG_OP
:触发触发器的操作(INSERT
、UPDATE
、DELETE
、...)
使用这些变量和其他触发器机制,您可以分析或更改正在进行的操作,甚至可以通过引发异常来中止它。
我建议阅读 the CREATE TRIGGER
statement and Trigger Procedure 的 Postgres 文档(最新的文档提供了大量示例)。