1)觸發器是一種特殊的存儲過程,觸發器一般由事件觸發并且不能接受參數,存儲器由語句塊去調用
2)觸發器分類:
1.DML觸發器: 創建在表上,由DML事件引發
2.instead of觸發器: 創建在視圖上并且只能在行級上觸發,用于替代insert,delete等操作(由于oracle中不能直接對有兩個以上的表建立的視圖進行DML操作,所以給出替代觸發器,它是專門為進行視圖操作的一種處理方法)
3.DDL觸發器: 觸發事件時數據庫對象的創建和修改
4.數據庫事件觸發器:定義在數據庫或者模式上,由數據庫事件觸發
3)組成:
1.觸發事件:引發觸發器被觸發的事件 DML語句(INSERT, UPDATE, DELETE語句對表或視圖執行數據處理操作)、DDL語句(如CREATE、ALTER、DROP語句在數據庫中創建、修改、刪除模式對象)、數據庫系統事件
(如系統啟動或退出、異常錯誤)、用戶事件(如登錄或退出數據庫)。
2.觸發時間:即該觸發器是在觸發事件發生之前(BEFORE)還是之后(AFTER)觸發
3.觸發操作:觸發器觸發后要完成的事情
4.觸發對象:包括表、視圖、模式、數據庫。只有在這些對象上發生了符合觸發條件的觸發事件,觸發器才會執行觸發操作。
5.觸發條件:由WHEN子句指定一個邏輯表達式。只有當該表達式的值為TRUE時,遇到觸發事件才會自動執行觸發操作。
6.觸發頻率:說明觸發器內定義的動作被執行的次數。即語句級(STATEMENT)觸發器和行級(ROW)觸發器。(比如delete多條數據時,行級觸發器可能會執行多次,語句級觸發器只會觸發一次) |
|