国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

SQL Sever 2000中的前觸發器和后觸發器

2024-07-21 02:42:56
字體:
來源:轉載
供稿:網友
我們知道,觸發器是一種特殊的存儲過程。當Insert Update或Delete語句修改表中一個或者多個行時就會執行觸發器。因為SQL Server對特定表上的每一個指定操作調用一個觸發器,所以可以使用觸發器擴展SQL Sever 的內置完整性和數據操縱功能。

(不像Delete 語句,Trancate Table 語句不激活觸發器,Write Text 語句也不激活觸發器)。

在SQL Sever 2000中支持兩種類型的觸發器,前觸發器(Instead Of Trigger)和后觸發器(After Trigger)。前觸發器就是在語句執行之前激活觸發器,而后觸發器就是在語句執行之后激活觸發器。可以通過FOR 子句來選擇使用何種觸發器。

當為每一種操作創建一個觸發器時,可以為所有三種操作創建一個觸發器,并且使用相應的編程技術處理每一種操作。下面的示例在For 子句中列出了三種語句類型,并且使用條件語句將相應的跟蹤值插入到CustUpdLog 表中。

Create Trigger TrackCustomerUpdatesOn AppDta.dbo.CustomerFor Insert,Update,DeleteAsDeclare @InsertedCount IntDeclare @DeletedCount IntSet @InsertedCount=(Select Count(*)From inserted)Set @DeletedCount=(Select Count(*)From deleted)If ( @InsertedCount>0)BeginInsert Into AppDta.dbo.CustUpdLog( CustID,Action,UpdUser,UpdDateTime)Select CustId,CaseWhen( @DeletedCount>0)Then'Update'Else 'Insert'End,Current_User,Current_TimeStampFrom insertedEndElse If(@DeletedCount>0)BeginInsert Into AppDta.dbo.CustUpdLog( CustId,Action,UpdUser,UpdDateTime)select CustId,'Delete',Current_User,Current_TimeStampFrom deletedEnd

從以上這個示例我們可以發現,無論何時Insert或者Update語句影響一個或者多行時,inserted 臨時表都有記錄行。無論何時Delete 或者Update 語句影響一個或者多行時,deleted 臨時表都有記錄行。對于一個Update 語句,deleted 臨時表有舊行,inserted 臨時表有新行。這個示例還反映了觸發器的另一個重要方面:對于某個表的Update 或者Delete 操作,即使該語句沒有影響到行,也激活觸發器 (也就是說沒有滿足Where 子句的行)。 觸發器的存儲過程應該預測這種可能性。

不僅可以為一個表創建多個觸發器,而且還可以為一個表的同一個SQL 語句(例如Update 語句)創建多個后觸發器,不能為同一個SQL 語句創建多個前觸發器。每一個新的Create Trigger 語句增加觸發器到那些指定表和語句已有的觸發器中。對于所創建的多個觸發器,可以用系統存儲過程sp_settriggerorder 來指定第一個被激活的觸發器和最后一個被激活的觸發器,而對于其他的觸發器,則不能指定其激活順序,只能由系統決定。這種觸發器的特征不會引起任何特殊的問題。因為總是可以實現各種動作作為正常的存儲過程,并且按照要求的順序從一個觸發器中調用它們。

盡管觸發器是一種存儲過程,但是不能使用Execute 語句調用它,如果有希望共享觸發器和正常的存儲過程的編碼,那么只需把共享代碼放在存儲過程中,從觸發器中調用它。如果一個觸發器修改一個表,那么這些修改可能會激活另一個觸發器,或者本身。在默認情況下,SQL Sever 允許這種嵌套的觸發器調用深度為32層。雖然我們建議允許嵌套的和疊代的觸發器,但是可以使用系統存儲過程禁止這么做。下面的語句在指定的數據庫上防止疊代觸發器:

sp_dboption AppDta,`recursive triggers',`false'

為了在所有數據庫中防止嵌套觸發器調用(包括疊代調用),可以使用下面的語句:

sp_configure `nested triggers',0

前面以后觸發器為例介紹了觸發器的基本內容,下面再介紹一下前觸發器的不同之處。要創建一個前觸發器必須用Instead Of 顯式聲明,如下面的例子:

create Trigger TrackCustomerUpdatesOn AppDta.dbo.CustomerInstead Of UpdateAsInsert Into AppDta.dbo.CustUpdLog(CustId,Action,UpdUser,UpdDateTime)Select CustId,‘Update’,Current_User,Current_TimeStampFrom inserted

與后觸發器不同的是:前觸發器既可以在表又可以在視圖上創建,但一條語句只能創建一個前觸發器,因此,前觸發器不存在激活順序問題

觸發器應用舉例:從當前數據庫服務器的Shop表Insert操作同步到另一臺服務器的Shop。

CREATE TRIGGER Trigger_SynShopForInsert1ON dbo.ShopFOR INSERTAS  insert into OtherServer.dbo.shop(lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex)select  lngShopID,strShopCode,strName,strShopName,strDescription,lngIndexfrom shop where lngShopID in (select lngshopid from inserted)

或者使用下面的語句:

CREATE TRIGGER Trigger_SynShopForInsert2ON dbo.ShopFOR INSERTAS  insert into OtherServer.dbo.shop(lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex)select  lngShopID,strShopCode,strName,strShopName,strDescription,lngIndexfrom  inserted

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 古蔺县| 永康市| 竹山县| 琼海市| 富民县| 军事| 泰顺县| 青川县| 尚义县| 达尔| 阳江市| 开阳县| 磐安县| 陆丰市| 蕉岭县| 延川县| 兖州市| 呼和浩特市| 剑阁县| 顺义区| 永寿县| 丽江市| 苍南县| 双城市| 南安市| 和顺县| 大同市| 深泽县| 内江市| 陇南市| 巴南区| 南川市| 宣汉县| 镶黄旗| 昌邑市| 赣榆县| 宁化县| 城口县| 陵水| 富宁县| 吉木乃县|