SQL Server 2000中的觸發(fā)器使用(good)文庫

SQL Server 2000中的觸發(fā)器使用(good)文庫

ID:40754802

大?。?0.00 KB

頁數(shù):4頁

時間:2019-08-07

SQL Server 2000中的觸發(fā)器使用(good)文庫_第1頁
SQL Server 2000中的觸發(fā)器使用(good)文庫_第2頁
SQL Server 2000中的觸發(fā)器使用(good)文庫_第3頁
SQL Server 2000中的觸發(fā)器使用(good)文庫_第4頁
資源描述:

《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

當前文檔最多預覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內(nèi)容,確認文檔內(nèi)容符合您的需求后進行下載,若出現(xiàn)內(nèi)容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。