Provided by: manpages-zh_1.6.3.2-1_all bug

NAME

       CREATE TRIGGER - 定義一個新的觸發器

SYNOPSIS

       CREATE TRIGGER name { BEFORE | AFTER } { event [ OR ... ] }
           ON table [ FOR [ EACH ] { ROW | STATEMENT } ]
           EXECUTE PROCEDURE funcname ( arguments )

DESCRIPTION 描述

       CREATE TRIGGER 創建一個新的觸發器。 觸發器將與指定表關聯並且將在特定事件發生時執行聲明的函
       數 func。

        觸發器可以聲明爲在對記錄進行操作之前(在檢查約束之前和  INSERT,UPDATE   或  DELETE  執行
       前)或操作完成之後(在檢查約束之後和完成   INSERT, UPDATE 或 DELETE 操作)觸發。 如果觸發
       器在事件之前,觸發器可能略過當前記錄的操作或改變被插入的(當前)記錄(只對    INSERT    和
       UPDATE  操作有效)。 如果觸發器在事件之後,所有更改,包括最後的插入, 更新或刪除對觸發器都
       是"可見"的。

        一個 FOR EACH ROW 執行指定操作的觸發器爲操作修改的每一行都調用一次。比如,一個影響 10  行
       的 DELETE 將導致任何在目標關係上的 ON DELETE 觸發器獨立調用 10 次, 每個被刪除的行一次。相
       比之下,一個爲指定操作 FOR EACH STATEMENT   的觸發器只是爲任何操作執行一次,不管有多少行被
       修改。  (特別是,一個修改零行的操作仍然會導致任何合適的  FOR  EACH  STATEMENT  觸發器的執
       行。)

        如果多個同類型的觸發器爲同樣事件做了定義, 那麼它們將按照字母順序被激活。

       SELECT 並不更改任何行,因此你不能創建 SELECT 觸發器。這種場合下規則和視圖更合適些。

        請參考 Part V ``Triggers'' 獲取更多信息。

PARAMETERS 參數

       name
               賦予新觸發器的名稱。它必需和任何作用於同一表的觸發器不同。

       BEFORE

       AFTER
               決定該函數是在事件之前還是之後調用。

       event  INSERT,DELETE 或 UPDATE 其中之一。  它聲明擊發觸發器的事件。多個事件可以用  OR  聲
              明。

       table  觸發器作用的表名稱(可以用模式修飾)。

       FOR EACH ROW

       FOR EACH STATEMENT
               這些選項聲明觸發器過程是否爲觸發器事件影響的每個行觸發一次, 還是隻爲每條 SQL 語句
              觸發一次。如果都沒有聲明, FOR EACH STATEMENT 是缺省。

       func   一個用戶提供的函數,它聲明爲不接受參數並且返回 trigger 類型。

       arguments
               一個可選的用逗號分隔的參數列表,它將在觸發器執行的時候提供給函數,  這些參數是文本
              字串常量。也可以在這裏寫簡單的名字和數值常量,但是它們會被轉換成字串。 請檢查實現語
              言中關於如何在觸發器函數中訪問觸發器參數的描述; 這些參數可能和普通的函數參數不同。

NOTES 注意

        要在一個表上創建一個觸發器,用戶必需在該表上有 TRIGGER 權限。

        在 PostgreSQL 版本  7.3  以前,  我們必須把觸發器函數聲明爲返回佔位類型  opaque,  而不是
       trigger。爲了支持裝載老的轉儲文件, CREATE TRIGGER 將接受一個聲明爲返回 opaque 的函數, 但
       是它將發出一條 NOTICE 並且把函數聲明的返回類型改成 trigger。

        用 DROP TRIGGER [drop_trigger(7)] 獲取如何刪除觸發器的信息。

EXAMPLES 例子

       Section 33.4 ``Triggers'' 包含一個完整的例子。

COMPATIBILITY 兼容性

       CREATE TRIGGER 裏的 CREATE TRIGGER 語句實現了一個 SQL99  標準的子集。  (SQL92  裏沒有觸發
       器) 目前仍然缺少下面的功能∶

       • SQL99 允許觸發器爲指定的字段的更新進行觸發(也就是說,AFTER UPDATE OF col1, col2)。

       • SQL99  允許你爲 "old" 和 "new" 行或者表定義別名,用於定義觸發器的動作(也就是說, CREATE
         TRIGGER ... ON tablename REFERENCING OLD ROW AS somename NEW ROW AS othername ...)。因爲
         PostgreSQL  允許觸發器過程以任意數量的用戶定義語言進行書寫,所以訪問數據的工作是用和語言
         相關的方法實現的。

       • PostgreSQL 只允許爲觸發的動作執行存儲的過程。SQL99 允許執行一些其他的 SQL 命令,  比如那
         CREATE  TABLE  作爲觸發器動作。 這個限止並不難繞開,只要創建一個執行這些命令的存儲過程即
         可。

       SQL99 要求多個觸發器應該以創建的時間順序執行。 PostgreSQL 採用的是按照名字順序,  我們認爲
       這樣更加方便。

        用 OR 給一個觸發器聲明多個動作是 PostgreSQL  對標準的擴展。

SEE ALSO 參見

       CREATE  FUNCTION  [create_function(7)],  ALTER  TRIGGER  [alter_trigger(l)],  DROP TRIGGER
       [drop_trigger(l)]

譯者

       Postgresql 中文網站 何偉平 <laser@pgsqldb.org>

       本頁面中文版由中文 man 手冊頁計劃提供。
       中文 man 手冊頁計劃:https://github.com/man-pages-zh/manpages-zh