2025年9月25日: PostgreSQL 18 釋出!
支援的版本: 當前 (18) / 17 / 16 / 15 / 14 / 13
開發版本: devel
不支援的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4

42.7. PL/Tcl 中的事件觸發器函式 #

事件觸發器函式可以用 PL/Tcl 編寫。 PostgreSQL 要求,要被呼叫為事件觸發器的函式必須宣告為無引數且返回型別為 event_trigger 的函式。

觸發器管理器中的資訊透過以下變數傳遞給函式體

$TG_event

觸發器被觸發的事件名稱。

$TG_tag

觸發器被觸發的命令標籤。

觸發器函式的返回值將被忽略。

這是一個簡單的事件觸發器函式示例,每次執行支援的命令時,它只會傳送一個 NOTICE 訊息。

CREATE OR REPLACE FUNCTION tclsnitch() RETURNS event_trigger AS $$
  elog NOTICE "tclsnitch: $TG_event $TG_tag"
$$ LANGUAGE pltcl;

CREATE EVENT TRIGGER tcl_a_snitch ON ddl_command_start EXECUTE FUNCTION tclsnitch();

提交更正

如果您在文件中看到任何不正確的內容、與您對特定功能的實際體驗不符的內容,或者需要進一步澄清的內容,請使用 此表單 報告文件問題。