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