postgresql上的更新类型

postgresql上的更新类型,sql,postgresql,plpgsql,stored-functions,Sql,Postgresql,Plpgsql,Stored Functions,这里是Postgres和PL/pgSQL的新增功能 如何编写PL/pgSQL函数来根据对postgres数据库中的表/记录进行的更新类型(插入、删除等)执行不同的操作。您似乎在寻找触发器 在SQL中,触发器是在对象上发生特定事件时调用(激发)的过程,例如在更新、删除或插入表时。触发器可以响应许多用例,例如实现业务完整性规则、清理数据、审核、安全性等等 在Postgres中,您应该首先定义PL/pgSQL函数,然后在触发器声明中引用它 CREATE OR REPLACE FUNCTION my_t

这里是Postgres和PL/pgSQL的新增功能


如何编写PL/pgSQL函数来根据对postgres数据库中的表/记录进行的更新类型(插入、删除等)执行不同的操作。

您似乎在寻找触发器

在SQL中,触发器是在对象上发生特定事件时调用(激发)的过程,例如在更新、删除或插入表时。触发器可以响应许多用例,例如实现业务完整性规则、清理数据、审核、安全性等等

在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
    :包含受查询影响的新/旧数据库记录的伪记录
  • TG\u OP
    :触发触发器的操作(
    INSERT
    UPDATE
    DELETE
    ,…)
使用这些变量和其他触发器机制,您可以分析或更改正在进行的操作,甚至可以通过引发异常中止操作


我建议您阅读Postgres文档,了解和(最新的文档提供了很多示例)。

您似乎在寻找一个触发器

在SQL中,触发器是在对象上发生特定事件时调用(激发)的过程,例如在更新、删除或插入表时。触发器可以响应许多用例,例如实现业务完整性规则、清理数据、审核、安全性等等

在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
    :包含受查询影响的新/旧数据库记录的伪记录
  • TG\u OP
    :触发触发器的操作(
    INSERT
    UPDATE
    DELETE
    ,…)
使用这些变量和其他触发器机制,您可以分析或更改正在进行的操作,甚至可以通过引发异常中止操作


我建议您阅读Postgres文档,了解和(最新的文档提供了许多示例)。

谢谢。是否可以在不使用触发器的情况下实现这一点?@vva:如果您想在特定事件发生时执行一些代码,触发器是一种方法。否则,您可以创建存储过程并从应用程序中调用它们。最后,您还可以处理应用程序中的所有逻辑。谢谢。在不使用触发器的情况下,是否可以实现这一点?@vva:如果您想在特定事件发生时执行一些代码,触发器是一种方法。否则,您可以创建存储过程并从应用程序中调用它们。最后,您还可以处理应用程序中的所有逻辑。