支援的版本: 目前 (17) / 16 / 15 / 14 / 13
開發版本: devel
不支援的版本: 12 / 11 / 10 / 9.6 / 9.5 / 9.4

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

事件觸發函數可以使用 PL/Tcl 編寫。PostgreSQL 要求要作為事件觸發器調用的函數,必須聲明為沒有參數且返回類型為 event_trigger 的函數。

來自觸發管理器 (trigger manager) 的資訊會透過以下變數傳遞到函數主體中:

$TG_event

觸發器觸發的事件名稱。

$TG_tag

觸發器觸發的指令標籤 (command 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();

提交更正

如果您在文件中發現任何不正確、與您對特定功能的體驗不符或需要進一步說明的內容,請使用此表單來回報文件問題。