資源描述:
《SQL Server 2000中的觸發(fā)器使用(good)文庫》由會員上傳分享,免費在線閱讀,更多相關內(nèi)容在行業(yè)資料-天天文庫。
1、SQLServer2000中的觸發(fā)器使用(good)文庫.txt我的優(yōu)點是:我很帥;但是我的缺點是:我?guī)浀牟幻黠@。什么是幸福?幸福就是貓吃魚,狗吃肉,奧特曼打小怪獸!令堂可是令尊表姐?我是胖人,不是粗人。SQLServer2000中的觸發(fā)器使用(good)觸發(fā)器是數(shù)據(jù)庫應用中的重用工具,它的應用很廣泛?! ?.INSERT觸發(fā)器的工作過程 可以定義一個無論何時用INSERT語句向表中插入數(shù)據(jù)時都會執(zhí)行的觸發(fā)器?! ‘斢|發(fā)INSERT觸發(fā)器時,新的數(shù)據(jù)行就會被插入到觸發(fā)器表和inserted表中。inserted表是一個邏輯表,它包含了已經(jīng)插入的數(shù)據(jù)行的一個副本。i
2、nserted表包含了INSERT語句中已記錄的插入動作。inserted表還允許引用由初始化INSERT語句而產(chǎn)生的日志數(shù)據(jù)。觸發(fā)器通過檢查inserted表來確定是否執(zhí)行觸發(fā)器動作或如何執(zhí)行它。inserted表中的行總是觸發(fā)器表中一行或多行的副本?! ∪罩居涗浟怂行薷臄?shù)據(jù)的動作(INSERT、UPDATE和DELETE語句),但在事務日志中的信息是不可讀的。然而,inserted表允許你引用由INSERT語句引起的日志變化,這樣就可以將插入數(shù)據(jù)與發(fā)生的變化進行比較,來驗證它們或采取進一步的動作。也可以直接引用插入的數(shù)據(jù),而不必將它們存儲到變量中?! ∈纠 ?/p>
3、在本例中,將創(chuàng)建一個觸發(fā)器。無論何時訂購產(chǎn)品(無論何時向OrderDetails表中插入一條記錄),這個觸發(fā)器都將更新Products表中的一列(UnitsInStock)。用原來的值減去訂購的數(shù)量值即為新值。USENorthwindCREATETRIGGEROrdDet_InsertON[OrderDetails]FORINSERTASUPDATEPSETUnitsInStock=P.UnitsInStock–I.QuantityFROMProductsASPINNERJOINInsertedASIONP.ProductID=I.ProductID 2.DELE
4、TE觸發(fā)器的工作過程 當觸發(fā)DELETE觸發(fā)器后,從受影響的表中刪除的行將被放置到一個特殊的deleted表中。deleted表是一個邏輯表,它保留已被刪除數(shù)據(jù)行的一個副本。deleted表還允許引用由初始化DELETE語句產(chǎn)生的日志數(shù)據(jù)?! ∈褂肈ELETE觸發(fā)器時,需要考慮以下的事項和原則: ·當某行被添加到deleted表中時,它就不再存在于數(shù)據(jù)庫表中;因此,deleted表和數(shù)據(jù)庫表沒有相同的行。 ·創(chuàng)建deleted表時,空間是從內(nèi)存中分配的。deleted表總是被存儲在高速緩存中。 ·為DELETE動作定義的觸發(fā)器并不執(zhí)行TRUNCATETABL
5、E語句,原因在于日志不記錄TRUNCATETABLE語句?! ∈纠 ≡诒纠?,將創(chuàng)建一個觸發(fā)器,無論何時刪除一個產(chǎn)品類別(即從Categories表中刪除一條記錄),該觸發(fā)器都會更新Products表中的Discontinued列。所有受影響的產(chǎn)品都標記為1,標示不再使用這些產(chǎn)品了。USENorthwindCREATETRIGGERCategory_DeleteONCategoriesFORDELETEASUPDATEPSETDiscontinued=1FROMProductsASPINNERJOINdeletedASdONP.CategoryID=d.Categ
6、oryID 3.UPDATE觸發(fā)器的工作過程 可將UPDATE語句看成兩步操作:即捕獲數(shù)據(jù)前像(beforeimage)的DELETE語句,和捕獲數(shù)據(jù)后像(afterimage)的INSERT語句。當在定義有觸發(fā)器的表上執(zhí)行UPDATE語句時,原始行(前像)被移入到deleted表,更新行(后像)被移入到inserted表?! ∮|發(fā)器檢查deleted表和inserted表以及被更新的表,來確定是否更新了多行以及如何執(zhí)行觸發(fā)器動作?! 】梢允褂肐FUPDATE語句定義一個監(jiān)視指定列的數(shù)據(jù)更新的觸發(fā)器。這樣,就可以讓觸發(fā)器容易的隔離出特定列的活動。當它檢測到指定列
7、已經(jīng)更新時,觸發(fā)器就會進一步執(zhí)行適當?shù)膭幼?,例如發(fā)出錯誤信息指出該列不能更新,或者根據(jù)新的更新的列值執(zhí)行一系列的動作語句?! ≌Z法:IFUPDATE() 本例阻止用戶修改Employees表中的EmployeeID列。USENorthwindGOCREATETRIGGEREmployee_UpdateONEmployeesFORUPDATEASIFUPDATE(EmployeeID)BEGINRAISERROR('Transactioncannotbeprocessed.*****EmployeeIDnumbercannotbemo