Oracle --觸發器

來源:互聯網
上載者:User

標籤:

觸發器在資料庫裡以獨立的Object Storage Service,它與預存程序不同的是,預存程序通過其它程式來啟動運行,而觸發器是由一個事件來啟動運行。

1. 觸發器特性

1>觸發器是當某個事件發生時自動的運行。

2>觸發器不能接收參數。

3>oracle事件指的是對資料庫表進行的insert、update、delete等操作。

2. 觸發器組成

2.1 觸發事件:引起觸發器被觸發的事件。例如:insert、update、delete等語句對錶或視圖的操作。

2.2 觸發時間:即該trigger是在觸發事件發生之前還是之後觸發。

2.3 觸發操作:即該trigger被觸發之後的目的和意圖,就是觸發器本身要做的事情。

2.4 觸發對象:包括表、視圖、模式、資料庫等,只有在這些對象上發生了符合觸發條件的觸發事件,才會執行觸發操作。

2.5 觸發條件:由when子句指定一個邏輯運算式,只有當該運算式的值為true時,遇到觸發事件才會自動執行觸發器,使其執行觸發操作。

2.6 觸發頻率:說明觸發器內定義的動作被執行的次數。即語句級觸發器(statement)和行級(row)觸發器。

語句級觸發器:當某觸發事件發生時,該觸發器只執行一次。

行級觸發器:當某觸發事件發生時,對受到該操作影響的每一行資料,觸發器都單獨執行一次。

3. 建立觸發器執行個體

create or replace trigger demo  before insert on t_user    declare  -- local variables herebegin  dbms_output.put_line(‘該觸發器已被執行!‘);  end demo;

向t_user表中添加資料

insert into t_user  (user_id, user_name, gender, age, telephone)values  (5, ‘王老吉‘, ‘0‘, 10, ‘13269368569‘)

查看觸發器是否被執行





Oracle --觸發器

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.