觸發(fā)器是一種特殊的存儲過程,它在插入,刪除或修改特定表中
的數(shù)據(jù)時觸發(fā)執(zhí)行,它比數(shù)據(jù)庫本身標(biāo)準(zhǔn)的功能有更精細和更復(fù)雜的
數(shù)據(jù)控制能力。
數(shù)據(jù)庫觸發(fā)器有以下的作用:
* 安全性??梢曰跀?shù)據(jù)庫的值使用戶具有操作數(shù)據(jù)庫的某種權(quán)
利。
# 可以基于時間限制用戶的操作,例如不允許下班后和節(jié)假日
修改數(shù)據(jù)庫數(shù)據(jù)。
# 可以基于數(shù)據(jù)庫中的數(shù)據(jù)限制用戶的操作,例如不允許股票
的價格的升幅一次超過10%。
* 審計??梢愿櫽脩魧?shù)據(jù)庫的操作。
# 審計用戶操作數(shù)據(jù)庫的語句。
# 把用戶對數(shù)據(jù)庫的更新寫入審計表。
* 實現(xiàn)復(fù)雜的數(shù)據(jù)完整性規(guī)則。
# 實現(xiàn)非標(biāo)準(zhǔn)的數(shù)據(jù)完整性檢查和約束。觸發(fā)器可產(chǎn)生比規(guī)則
更為復(fù)雜的限制。與規(guī)則不同,觸發(fā)器可以引用列或數(shù)據(jù)庫對
象。例如,觸發(fā)器可回退任何企圖吃進超過自己保證金的期貨。
# 提供可變的缺省值。
* 實現(xiàn)復(fù)雜的非標(biāo)準(zhǔn)的數(shù)據(jù)庫相關(guān)完整性規(guī)則。觸發(fā)器可以對數(shù)
據(jù)庫中相關(guān)的表進行連環(huán)更新。例如,在auths表author_code列上的
刪除觸發(fā)器可導(dǎo)致相應(yīng)刪除在其它表中的與之匹配的行。
# 在修改或刪除時級聯(lián)修改或刪除其它表中的與之匹配的行。
# 在修改或刪除時把其它表中的與之匹配的行設(shè)成NULL值。
# 在修改或刪除時把其它表中的與之匹配的行級聯(lián)設(shè)成缺省值。
# 觸發(fā)器能夠拒絕或回退那些破壞相關(guān)完整性的變化,取消試
圖進行數(shù)據(jù)更新的事務(wù)。當(dāng)插入一個與其主健不匹配的外部鍵
時,這種觸發(fā)器會起作用。例如,可以在books.author_code
列上生成一個插入觸發(fā)器,如果新值與auths.author_code列
中的某值不匹配時,插入被回退。
* 同步實時地復(fù)制表中的數(shù)據(jù)。
* 自動計算數(shù)據(jù)值,如果數(shù)據(jù)的值達到了一定的要求,則進行特
定的處理。例如,如果公司的帳號上的資金低于5萬元則立即給財務(wù)人
員發(fā)送警告數(shù)據(jù)。
觸發(fā)器是一種特殊的存儲過程,類似于事件函數(shù),SQL Server™ 允許為 INSERT、UPDATE、DELETE 創(chuàng)建觸發(fā)器,即當(dāng)在表中插入、更新、刪除記錄時,觸發(fā)一個或一系列 T-SQL語句。
觸發(fā)器可以在查詢分析器里創(chuàng)建,也可以在表名上點右鍵->“所有任務(wù)”->“管理觸發(fā)器”來創(chuàng)建,不過都是要寫 T-SQL 語句的,只是在查詢分析器里要先確定當(dāng)前操作的數(shù)據(jù)庫。
創(chuàng)建觸發(fā)器用 CREATE TRIGGER
CREATE TRIGGER 觸發(fā)器名稱
ON 表名
FOR INSERT、UPDATE 或 DELETE
AS
T-SQL 語句
注意:觸發(fā)器名稱是不加引號的。
如下是聯(lián)機叢書上的一個示例,當(dāng)在 titles 表上更改記錄時,發(fā)送郵件通知 MaryM。
CREATE TRIGGER reminder
ON titles
FOR INSERT, UPDATE, DELETE
AS
EXEC master..xp_sendmail 'MaryM',
'Don''t forget to print a report for the distributors.'
posted on 2009-02-19 15:42
天書 閱讀(3625)
評論(1) 編輯 收藏 引用