資源描述:
《sql server數(shù)據(jù)庫觸發(fā)器實例講解文章出處》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。
1、SqlServer數(shù)據(jù)庫觸發(fā)器實例講解文章出處定義:何為觸發(fā)器?在SQLServer里面也就是對某一個表的一定的操作,觸發(fā)某種條件,從而執(zhí)行的一段程序。觸發(fā)器是一個特殊的存儲過程。常見的觸發(fā)器有三種:分別應用于Insert,Update,Delete事件。(SQLServer2000定義了新的觸發(fā)器,這里不提)我為什么要使用觸發(fā)器?比如,這么兩個表:CreateTableStudent(--學生表StudentIDintprimarykey,--學號)CreateTableBorrowRecord(--學生
2、借書記錄表BorrowRecordintidentity(1,1),--流水號StudentIDint,--學號BorrowDatedatetime,--借出時間ReturnDAteDatetime,--歸還時間...)用到的功能有:1.如果我更改了學生的學號,我希望他的借書記錄仍然與這個學生相關(guān)(也就是同時更改借書記錄表的學號);2.如果該學生已經(jīng)畢業(yè),我希望刪除他的學號的同時,也刪除它的借書記錄。等等。這時候可以用到觸發(fā)器。對于1,創(chuàng)建一個Update觸發(fā)器:CreateTriggertruStuden
3、tOnStudent--在Student表中創(chuàng)建觸發(fā)器forUpdate--為什么事件觸發(fā)As--事件觸發(fā)后所要做的事情ifUpdate(StudentID)beginUpdateBorrowRecordSetStudentID=i.StudentIDFromBorrowRecordbr,Deletedd,Insertedi--Deleted和Inserted臨時表Wherebr.StudentID=d.StudentIDend理解觸發(fā)器里面的兩個臨時的表:Deleted,Inserted。注意Delete
4、d與Inserted分別表示觸發(fā)事件的表“舊的一條記錄”和“新的一條記錄”。一個數(shù)據(jù)庫系統(tǒng)中有兩個虛擬表用于存儲在表中記錄改動的信息,分別是:虛擬表Inserted虛擬表Deleted在表記錄新增時存放新增的記錄不存儲記錄修改時存放用來更新的新記錄存放更新前的記錄刪除時不存儲記錄存放被刪除的記錄一個Update的過程可以看作為:生成新的記錄到Inserted表,復制舊的記錄到Deleted表,然后刪除Student記錄并寫入新紀錄。對于2,創(chuàng)建一個Delete觸發(fā)器CreatetriggertrdStude
5、ntOnStudent-28-forDeleteAsDeleteBorrowRecordFromBorrowRecordbr,DelteddWherebr.StudentID=d.StudentID從這兩個例子我們可以看到了觸發(fā)器的關(guān)鍵:A.2個臨時的表;B.觸發(fā)機制。這里我們只講解最簡單的觸發(fā)器。復雜的容后說明。事實上,我不鼓勵使用觸發(fā)器。觸發(fā)器的初始設(shè)計思想,已經(jīng)被“級聯(lián)”所替代SQLSERVER觸發(fā)器觸發(fā)器是數(shù)據(jù)庫應用中的重用工具,它的應用很廣泛。這幾天寫一個化學數(shù)據(jù)統(tǒng)計方面的軟件,需要根據(jù)采樣,自動
6、計算方差,在這里,我使用了觸發(fā)器。 可以定義一個無論何時用INSERT語句向表中插入數(shù)據(jù)時都會執(zhí)行的觸發(fā)器?! ‘斢|發(fā)INSERT觸發(fā)器時,新的數(shù)據(jù)行就會被插入到觸發(fā)器表和inserted表中。inserted表是一個邏輯表,它包含了已經(jīng)插入的數(shù)據(jù)行的一個副本。inserted表包含了INSERT語句中已記錄的插入動作。inserted表還允許引用由初始化INSERT語句而產(chǎn)生的日志數(shù)據(jù)。觸發(fā)器通過檢查inserted表來確定是否執(zhí)行觸發(fā)器動作或如何執(zhí)行它。inserted表中的行總是觸發(fā)器表中一行或多行
7、的副本。 日志記錄了所有修改數(shù)據(jù)的動作(INSERT、UPDATE和DELETE語句),但在事務(wù)日志中的信息是不可讀的。然而,inserted表允許你引用由INSERT語句引起的日志變化,這樣就可以將插入數(shù)據(jù)與發(fā)生的變化進行比較,來驗證它們或采取進一步的動作。也可以直接引用插入的數(shù)據(jù),而不必將它們存儲到變量中?! ∈纠 ≡诒纠?,將創(chuàng)建一個觸發(fā)器。無論何時訂購產(chǎn)品(無論何時向OrderDetails表中插入一條記錄),這個觸發(fā)器都將更新Products表中的一列(UnitsInStock)。用原來的值減
8、去訂購的數(shù)量值即為新值。USENorthwindCREATETRIGGEROrdDet_InsertON[OrderDetails]FORINSERTASUPDATEPSETUnitsInStock=P.UnitsInStock–I.QuantityFROMProductsASPINNERJOINInsertedASIONP.ProductID=I.ProductID DELETE觸發(fā)器的工作過程 當觸發(fā)DE