国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Oracle > 正文

oracle觸發器使用總結

2024-07-15 01:59:50
字體:
來源:轉載
供稿:網友

觸發器 是特定事件出現的時候,自動執行的代碼塊。類似于存儲過程,但是用戶不能直接調用他們。觸發器是許多關系數據庫系統都提供的一項技術。在ORACLE系統里,觸發器類似過程和函數,都有聲明,執行和異常處理過程的PL/SQL塊。

1.說明

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多條數據時,行級觸發器可能會執行多次,語句級觸發器只會觸發一次)       

2.語法

1)說明

不同類型的觸發器例如DML觸發器,Instead of觸發器,系統觸發器語法格式區別較大

2)一般語法

  CREATE [OR REPLACE] TIGGER觸發器名 觸發時間 觸發事件  ON表名/視圖名  [FOR EACH ROW]  //加上FOR EACH ROW 即為行級觸發器,不加時為語句級觸發器  BEGIN  pl/sql語句  END
    create [or replace] trigger [schema.]trigger_name      {before | after | instead of}      {delete [or insert][or update [of column,...n]]}      on [schema.]table_name | view_name      [for each row [when(condition)]]      sql_statement[,...n]            
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 交口县| 锦屏县| 莒南县| 河源市| 衡阳县| 清苑县| 新郑市| 武威市| 惠东县| 仁布县| 金塔县| 南华县| 荥经县| 江安县| 奉贤区| 土默特左旗| 纳雍县| 海晏县| 松滋市| 大城县| 南部县| 晋中市| 宁远县| 楚雄市| 天柱县| 镇原县| 德州市| 千阳县| 杭州市| 砀山县| 依兰县| 泰来县| 合阳县| 汤原县| 康定县| 维西| 锦州市| 资源县| 乐至县| 雷山县| 谷城县|