版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
觸發(fā)器的操作與管理第1頁,共32頁,2023年,2月20日,星期四TriggerViewTriggerisaspecialkindofstoredprocedure,itcanbeeffectiveautomaticallywhileexecutingLanguageevent.觸發(fā)器是一種特殊的存儲過程,它在執(zhí)行語言事件時自動生效。SQLServer2005包括兩大類觸發(fā)器:DML觸發(fā)器和DDL觸發(fā)器。
(1)
DMLTriggerwillstartwhileoperatingdataindatabase.DMLeventsincludestheINSERT,UPDATEandDELETEstatement.DMLtrigger,DMLtriggercanqueryothertables,canincludecomplexTransact-SQLstatement.TheTriggerandthestatementbelongstothetriggeristreatedasasingletransactionwhichcanberolledback.Ifthefaultisdetected(forexamplediskisfull),thewholetransactionwillberolledback.DML觸發(fā)器在數(shù)據(jù)庫中發(fā)生數(shù)據(jù)操作語言(DML)事件時將啟用。DML事件包括在指定表或視圖中修改數(shù)據(jù)的INSERT語句、UPDATE語句或DELETE語句。DML觸發(fā)器可以查詢其他表,還可以包含復(fù)雜的Transact-SQL語句。將觸發(fā)器和觸發(fā)它的語句作為可在觸發(fā)器內(nèi)回滾的單個事務(wù)對待。如果檢測到錯誤(例如,磁盤空間不足),則整個事務(wù)即自動回滾。
第2頁,共32頁,2023年,2月20日,星期四(2)DDLTriggeristhenewincreasedfunctionofSQLServer2005.
DMLTriggerwillstartwhileDDLeventoccurs.
DDL觸發(fā)器是SQLServer2005的新增功能。當(dāng)服務(wù)器或數(shù)據(jù)庫中發(fā)生數(shù)據(jù)定義語言(DDL)事件時將調(diào)用這些觸發(fā)器。第3頁,共32頁,2023年,2月20日,星期四11.1DML觸發(fā)器的創(chuàng)建和應(yīng)用
TriggerwillbecalledWhentheDMLeventofdatabaseoccurs,itmakessuredataoperationtoobeytheruleofsuchSQLstatement.
當(dāng)數(shù)據(jù)庫中發(fā)生數(shù)據(jù)操作語言(DML)事件時將調(diào)用DML觸發(fā)器。從而確保對數(shù)據(jù)的處理必須符合由這些SQL語句所定義的規(guī)則。第4頁,共32頁,2023年,2月20日,星期四
DML觸發(fā)器的主要優(yōu)點如下:(1)DMLTriggercanmaketherelatedtablescascadechange.Forexample,Youcanmakeadeletingtriggeronthecolomnsnoofthetablestudent,whenyoudeletethedataofstudenttable,therelatedrecordsofthetablescwillbealsodeleted.
DML觸發(fā)器可通過數(shù)據(jù)庫中的相關(guān)表實現(xiàn)級聯(lián)更改。例如,可以在student表的sno列上寫入一個刪除觸發(fā)器,以使其他表中的各匹配行采取刪除操作。該觸發(fā)器用sno列作為惟一鍵,在sc表中對各匹配行進(jìn)行定位。第5頁,共32頁,2023年,2月20日,星期四(2)DMLtriggercanpreventthemaliceorthefaultoftheoperationsofINSERT,UPDATEandDELETE,andenforcetoexecutethemorecomplexconstraintthenalimitationofacheck.
DML觸發(fā)器可以防止惡意或錯誤的INSERT、UPDATE以及DELETE操作,并強制執(zhí)行比CHECK約束定義的限制更為復(fù)雜的其他限制。與CHECK約束不同,DML觸發(fā)器可以引用其他表中的列。(3)DMLtriggercanevaluatethestatesofatablebeforechangingorafterchanging,itcantakesomeactionsaccordingtothedifference.
DML觸發(fā)器可以評估數(shù)據(jù)修改前后表的狀態(tài),并根據(jù)該差異采取措施。
第6頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建
Whenyoucreateatrigger,thefollowingoptionsmustbedenoted:當(dāng)創(chuàng)建一個觸發(fā)器時必須指定如下選項:
(1)Anameofthetrigger名稱;(2)Thetablewhichthetriggerisdefinedon
在其上定義觸發(fā)器的表;(3)Thetimewhenthetriggeristriggered:觸發(fā)器將何時激發(fā);(4)Thedatachangingstatementwhichcanwakethetrigger,moredatachangingstatementscanwakeonesametrigger.激活觸發(fā)器的數(shù)據(jù)修改語句,有效選項為INSERT、UPDATE或DELETE,多個數(shù)據(jù)修改語句可激活同一個觸發(fā)器;(5)Theprogrammingstatementwhichexecutetriggeroperation.執(zhí)行觸發(fā)操作的編程語句。
第7頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建DMLtriggeruseadeletedlogicaltableandainsertedlogicaltable.Theyhavethesamestructureasthebasictable,SQLServercancreateandmanagethetablesautomatically.Thetwologicaltableswhichstayatthememorytemporarycanbeusedtotesttheeffectiveofdatachangingandcansettheconditionoftriggeroperation.
DML觸發(fā)器使用deleted和inserted邏輯表。它們在結(jié)構(gòu)上和觸發(fā)器所在的表的結(jié)構(gòu)相同,SQLServer會自動創(chuàng)建和管理這些表??梢允褂眠@兩個臨時的駐留內(nèi)存的表測試某些數(shù)據(jù)修改的效果及設(shè)置觸發(fā)器操作的條件。 第8頁,共32頁,2023年,2月20日,星期四DeletedtableisusedtostorethecopyofthedataDeletedorupdated.Whenthestatementexecutes,thedataisdeletedandstoredintothedeletedtable.表用于存儲delete,update語句所影響的行的副本。在執(zhí)行delete或update語句時,行從觸發(fā)器表中刪除,并傳輸?shù)絛eleted表中。Insertedtableisusedtostorethecopyofthedatainsertedorupdated.Inainsertingoraupdatingtransaction,thenewrecordwillbeinsertedintotheinsertedtableandthebasictable.Therecordoftheinsertedtableisthedatacopyofthebasictable.表用于存儲Insert或update語句所影響的行的副本,在一個插入或更新事務(wù)處理中,新建的行被同時添加到Inserted表和觸發(fā)器表中。Inserted表中的行是觸發(fā)器表中新行的副本。第9頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建使用SQLServer管理平臺創(chuàng)建觸發(fā)器的過程如下:在SQLServer管理平臺中,展開指定的服務(wù)器和數(shù)據(jù)庫項,然后展開表,選擇并展開要在其上創(chuàng)建觸發(fā)器的表,如圖9-1所示,右擊觸發(fā)器選項,從彈出的快捷菜單中選擇“新建觸發(fā)器”選項,則會出現(xiàn)觸發(fā)器創(chuàng)建窗口,如圖9-2所示。最后,單擊“執(zhí)行”按鈕,即可成功創(chuàng)建觸發(fā)器。圖9-1新建觸發(fā)器對話框
圖9-2新建觸發(fā)器窗口
第10頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建使用CREATETRIGGER命令創(chuàng)建DML觸發(fā)器的語法形式如下:
CREATETRIGGER[schema_name.]trigger_nameON{table|view}[WITH[ENCRYPTION]EXECUTEASClause][,...n]]{FOR|AFTER|INSTEADOF}{[INSERT][,][UPDATE][,][DELETE]}[WITHAPPEND][NOTFORREPLICATION]AS{sql_statement[;][...n]|EXTERNALNAME<methodspecifier[;]>}<method_specifier>::=assembly_name.class_name.method_name
第11頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建例9-1示例說明inserted,deleted表的作用。執(zhí)行結(jié)果如右圖。程序清單如下:createtablesc(snochar(10),cnochar(2),scorereal)GoCREATETRIGGERtr1ONscFORINSERT,UPDATE,DELETEASPRINT‘inserted表:’Select*frominsertedPRINT‘deleted表:’Select*fromdeletedGo圖9-3觸發(fā)器的執(zhí)行結(jié)果
第12頁,共32頁,2023年,2月20日,星期四11.1.1DML觸發(fā)器創(chuàng)建例9-2
createatrigger,whichisforinsertingandupdatingdataoftables
創(chuàng)建一個觸發(fā)器,在s表上創(chuàng)建一個插入、更新類型的觸發(fā)器。程序清單如下:CREATETRIGGERtr_sONsFORINSERT,UPDATEASBeginDECLARE@bhvarchar(6)SELECT@bh=inserted.snoFROMinserted/*獲取插入或更新操作時的新值(學(xué)號)*/End
第13頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
1.使用INSERT觸發(fā)器INSERT觸發(fā)器通常被用來更新時間標(biāo)記字段,或者驗證被觸發(fā)器監(jiān)控的字段中數(shù)據(jù)滿足要求的標(biāo)準(zhǔn),以確保數(shù)據(jù)的完整性。例9-3建立一個觸發(fā)器,當(dāng)向sc表中添加數(shù)據(jù)時,如果添加的數(shù)據(jù)與s表中的數(shù)據(jù)不匹配(沒有對應(yīng)的學(xué)號),則將此數(shù)據(jù)刪除。(thistriggerisusedtoreplacetheforeignconstraint)程序清單如下:CREATETRIGGERsc_insONscFORINSERTASBEGINDECLARE@bhchar(5)Select@bh=Inserted.snofromInsertedIfnotexists(selectsnofromswheres.sno=@bh)Deletescwheresno=@bhEND
第14頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
1.使用INSERT觸發(fā)器例9-4創(chuàng)建一個觸發(fā)器,當(dāng)插入或更新成績列時,該觸發(fā)器檢查插入的數(shù)據(jù)是否處于設(shè)定的范圍內(nèi)(thisistriggerisusedtoreplacecheckconstraint)。程序清單如下:CREATETRIGGERsc_insupdONscFORINSERT,UPDATEASDECLARE@cjint,SELECT@cj=inserted.scorefrominsertedIF(@cj<0or@cj>100)BEGINRAISERROR('成績的取值必須在0到100之間',16,1)
ROLLBACKTRANSACTIONEND
第15頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
2.使用UPDATE觸發(fā)器
當(dāng)在一個有UPDATE觸發(fā)器的表中修改記錄時,表中原來的記錄被移動到刪除表中,修改過的記錄插入到了插入表中,觸發(fā)器可以參考刪除表和插入表以及被修改的表,以確定如何完成數(shù)據(jù)庫操作。例9-5創(chuàng)建一個修改觸發(fā)器,該觸發(fā)器防止用戶修改表s的入學(xué)成績。程序清單如下:createtriggertri_s_updonsforupdateasifupdate(escore)beginraiserror(‘不能修改入學(xué)成績’,16,10)rollbacktransactionendgo
第16頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
使用UPDATE觸發(fā)例9-6DAS數(shù)據(jù)庫由存放實時數(shù)據(jù)的數(shù)據(jù)表以及存放歷史數(shù)據(jù)的歷史表組成。由于存放實時數(shù)據(jù)的數(shù)據(jù)表不斷更新,為了保存更新過的數(shù)據(jù),在實時表和歷史表之間建立了觸發(fā)器。程序清單如下:CREATETRIGGERDasD_UTRIGGERONDasDFORUPDATEASBEGINIFUpdate(TV)/*數(shù)據(jù)更新*/BEGINUPDATEDasDSETUT=getdate() /*更新時間*/FROMDasD,insertedWHEREDasD.ID=inserted.ID INSERTDasDHis(ID,TV,UT)SELECTinserted.ID,inserted.TV,DasD.UTFROMDasD,insertedWHEREDasD.ID=inserted.ID/*將更新過的數(shù)據(jù)送入歷史庫*/ENDEND第17頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
3.使用DELETE觸發(fā)器
DELETE觸發(fā)器通常用于兩種情況,第一種情況是為了防止那些確實需要刪除但會引起數(shù)據(jù)一致性問題的記錄的刪除,第二種情況是執(zhí)行可刪除主記錄的子記錄的級聯(lián)刪除操作。例9-8建立一個與s表結(jié)構(gòu)一樣的表s1,當(dāng)刪除表s中的記錄時,自動將刪除掉的記錄存放到s1表中。程序清單如下:CREATETRIGGERtr_delONs/*建立觸發(fā)器FORDELETE /*對表刪除操作ASinserts1select*fromdeleted/*將刪除掉的數(shù)據(jù)送入表s1中*/GO第18頁,共32頁,2023年,2月20日,星期四11.1.2
DML觸發(fā)器的應(yīng)用
3.使用DELETE觸發(fā)器
例9-9當(dāng)刪除表s中的記錄時,自動刪除表sc中對應(yīng)學(xué)號的記錄。程序清單如下:CREATETRIGGERtr_del_sONsFORDELETEBEGINDECLARE@bhchar(5)Select@bh=deleted.snofromdeletedDeletescwheresno=@bhEND第19頁,共32頁,2023年,2月20日,星期四11.2DDL觸發(fā)器的創(chuàng)建和應(yīng)用
DDL觸發(fā)器會為響應(yīng)多種數(shù)據(jù)定義語言(DDL)語句而激發(fā)。這些語句主要是以CREATE、ALTER和DROP開頭的語句。DDL觸發(fā)器可用于管理任務(wù),例如審核和控制數(shù)據(jù)庫操作。DDL觸發(fā)器一般用于以下目的:(1)防止對數(shù)據(jù)庫架構(gòu)進(jìn)行某些更改;(2)希望數(shù)據(jù)庫中發(fā)生某種情況以響應(yīng)數(shù)據(jù)庫架構(gòu)中的更改;(3)要記錄數(shù)據(jù)庫架構(gòu)中的更改或事件。僅在運行觸發(fā)DDL觸發(fā)器的DDL語句后,DDL觸發(fā)器才會激發(fā)。DDL觸發(fā)器無法作為INSTEADOF觸發(fā)器使用。
第20頁,共32頁,2023年,2月20日,星期四11.2.1創(chuàng)建DDL觸發(fā)器
使用CREATETRIGGER命令創(chuàng)建DDL觸發(fā)器的語法形式如下:
CREATETRIGGERtrigger_nameON{ALLSERVER|DATABASE}[WITH<ddl_trigger_option>[,...n]]{FOR|AFTER}{event_type|event_group}[,...n]AS{sql_statement[;][...n]|EXTERNALNAME<methodspecifier>[;]}其中:
<ddl_trigger_option>::=[ENCRYPTION]EXECUTEASClause]<method_specifier>::=assembly_name.class_name.method_name第21頁,共32頁,2023年,2月20日,星期四11.2.2DDL觸發(fā)器的應(yīng)用
在響應(yīng)當(dāng)前數(shù)據(jù)庫或服務(wù)器中處理的Transact-SQL事件時,可以激發(fā)DDL觸發(fā)器。觸發(fā)器的作用域取決于事件。例9-11使用DDL觸發(fā)器來防止數(shù)據(jù)庫中的任一表被修改或刪除。程序清單如下:
CREATETRIGGERsafetyONDATABASEFORDROP_TABLE,ALTER_TABLEASPRINT'YoumustdisableTrigger"safety"todroporaltertables!'ROLLBACK第22頁,共32頁,2023年,2月20日,星期四11.2.2DDL觸發(fā)器的應(yīng)用例9-12使用DDL觸發(fā)器來防止在數(shù)據(jù)庫中創(chuàng)建表。程序清單如下:
CREATETRIGGERsafetyONDATABASEFORCREATE_TABLEASPRINT'CREATETABLEIssued.'SELECTEVENTDATA().value('(/EVENT_INSTANCE/TSQLCommand/CommandText)[1]','nvarchar(max)')RAISERROR('Newtablescannotbecreatedinthisdatabase.',16,1)ROLLBACK第23頁,共32頁,2023年,2月20日,星期四11.3DDL查看、修改和刪除觸發(fā)器11.3.1查看觸發(fā)器11.3.2修改觸發(fā)器11.3.3刪除觸發(fā)器第24頁,共32頁,2023年,2月20日,星期四11.3.1查看觸發(fā)器
如果要顯示作用于表上的觸發(fā)器究竟對表有哪些操作,必須查看觸發(fā)器信息。在SQLServer中,有多種方法可以查看觸發(fā)器信息,其中最常用的有如下兩種:(1)使用SQLServer管理平臺查看觸發(fā)器信息;(2)使用系統(tǒng)存儲過程查看觸發(fā)器。第25頁,共32頁,2023年,2月20日,星期四11.3.1查看觸發(fā)器(1)使用SQLServer管理平臺查看觸發(fā)器信息。在SQLServer管理平臺中,展開服務(wù)器和數(shù)據(jù)庫,選擇并展開表,然后展開觸發(fā)器選項,右擊需要查看的觸發(fā)器名稱,如圖9-4所示,從彈出的快捷菜單中,選擇“編寫觸發(fā)器腳本為→create到→新查詢編輯器窗口”,則可以看到觸發(fā)器的源代碼。圖9-4查看觸發(fā)器
第26頁,共32頁,2023年,2月20日,星期四11.3.1查看觸發(fā)器(2)使用系統(tǒng)存儲過程查看觸發(fā)器。系統(tǒng)存儲過程sp_help、sp_helptext和sp_depends分別提供有關(guān)觸發(fā)器的不同信息。其具體用途和語法形式如下。sp_help:用于查看觸發(fā)器的一般信息,如觸發(fā)器的名稱、屬性、類型和創(chuàng)建時間。
sp_help‘觸發(fā)器名稱’sp_helptext:用于查看觸發(fā)器的正文信息。
sp_helptext‘觸發(fā)器名稱’sp_depends:用于查看指定觸發(fā)器所引用的表或者指定的表涉及到的所有觸發(fā)器。
sp_depends‘觸發(fā)器名稱’
sp_depends‘表名’第27頁,共32頁,2023年,2月20日,星期四11.3.2修改觸發(fā)器通過SQLServer管理平臺、存儲過程,可以修改觸發(fā)器的正文和名稱。1.使用SQLServer管理平臺修改觸發(fā)器正文。在管理平臺中,展開指定的表,右擊要修改的觸發(fā)器,從彈出的快捷菜單中選擇“修改”選項,則會出現(xiàn)觸發(fā)器修改窗口,如圖9-5所示。在文本框中修改觸發(fā)器的SQL語句,單擊“語法檢查”按鈕,可以檢查語法是否正確,單擊“執(zhí)行”按鈕,可以成功修改此觸發(fā)器。圖9-5觸發(fā)器修改窗口
第28頁,共32頁,2023年,2月20日,星期四11.3.2修改觸發(fā)器修改DML觸發(fā)器的語法形式如下:
ALTERTRIGGERschema_name.trigger_nameON(table|view)[WITH<dml_trigger_option>[,...n]](FOR|AFTER|INSTEADOF){[DELETE][,][INSERT][,][UPDATE]}[NOTFORREPLICATION]AS
{sql_statement[;][...n]|EXTERNALNAME<methodspecifier>[;]}<dml_trigger_option>::=[ENCRYPTION][&lEXECUTEASClause>]<method_specifier>::=assembly_name.class_name.method
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2023年運載火箭遙測系統(tǒng)檢測設(shè)備投資申請報告
- 2023年會議電視圖像保密機資金申請報告
- 黃石市初中畢業(yè)生學(xué)業(yè)考試語文模擬試卷
- 6高中數(shù)學(xué)新教材課堂導(dǎo)學(xué)案(直線的方程)及答案
- 山東省濟南市槐蔭區(qū)西城實驗學(xué)校2024-2025學(xué)年八年級上學(xué)期開學(xué)考試數(shù)學(xué)試題
- 電視節(jié)目自動播出設(shè)備相關(guān)行業(yè)投資方案
- 歷史知識清單2024~2025學(xué)年統(tǒng)編版九年級歷史上冊
- 協(xié)作辦公順暢性
- 氟伐他汀的長期安全性評估
- 港口數(shù)據(jù)智能化管理
- 2024-2030年中國硬質(zhì)合金帶鋸條行業(yè)發(fā)展現(xiàn)狀及市場投資趨勢洞察研究報告
- 《法律職業(yè)倫理(第三版)》課件全套 王進(jìn)喜 第1-21章 法律職業(yè)-司法鑒定職業(yè)倫理
- 2024廣東深圳燃?xì)庑@招聘(高頻重點提升專題訓(xùn)練)共500題附帶答案詳解
- 2024廣東東莞市煙草專賣局(公司)招聘9人(高頻重點提升專題訓(xùn)練)共500題附帶答案詳解
- 2024版Purchase Contract(采購合同范本英文版)
- 4.1 10的再認(rèn)識-一年級上冊數(shù)學(xué)課件
- 新質(zhì)生產(chǎn)力與高質(zhì)量發(fā)展答案-2024公需課
- 2024年山西晉城高平市綜治中心招聘專職網(wǎng)格員136人歷年(高頻重點復(fù)習(xí)提升訓(xùn)練)共500題附帶答案詳解
- 10J301 地下建筑防水構(gòu)造
- 中國移動投資生態(tài)白皮書(2024年版)
- 蘇科版(2015)信息技術(shù)五年級 第3課 火柴人跳舞 課件
評論
0/150
提交評論