亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

前觸發器和后觸發器簡介(downmoon)

系統 2249 0
                前觸發器和后觸發器簡介(downmoon)

???  觸發器是一種特殊的存儲過程。當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 TrackCustomerUpdates
???On AppDta.dbo.Customer
??????For Insert,Update,Delete
???As
??????Declare @InsertedCount Int
??????Declare @DeletedCount Int
??????Set @InsertedCount=(Select Count(*)From inserted)
??????Set @DeletedCount=(Select Count(*)From deleted)
??????If ( @InsertedCount>0)
?????????Begin
????????????Insert Into AppDta.dbo.CustUpdLog
????????????( CustID,
???????????????Action,
???????????????UpdUser,
???????????????UpdDateTime)
????????????Select CustId,
????????????Case
????????????When( @DeletedCount>0)Then
????????????'Update'
????????Else 'Insert'
??????End,
Current_User,
Current_TimeStamp
From inserted
End
Else If(@DeletedCount>0)Begin
Insert Into AppDta.dbo.CustUpdLog
( CustId,
Action,
UpdUser,
UpdDateTime)
select CustId,
'Delete',
Current_User,
Current_TimeStamp
From deleted
End
??? 正如本例所示,無論何時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 TrackCustomerUpdates
On AppDta.dbo.Customer
Instead Of Update
As
Insert Into AppDta.dbo.CustUpdLog
(CustId,
Action,
UpdUser,
UpdDateTime)
Select CustId,
‘Update’,
Current_User,
Current_TimeStamp
From inserted
??? 與后觸發器不同的是:前觸發器既可以在表又可以在視圖上創建,但一條語句只能創建一個前觸發器,因此,前觸發器不存在激活順序問題


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

CREATE TRIGGER Trigger_SynShopForInsert1
ON dbo.Shop
FOR INSERT
AS
? insert into OtherServer.dbo.shop
(
lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex
)
select? lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex
from shop where lngShopID in (select lngshopid from inserted)

或者:

CREATE TRIGGER Trigger_SynShopForInsert2
ON dbo.Shop
FOR INSERT
AS
? insert into OtherServer.dbo.shop
(
lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex
)
select? lngShopID,strShopCode,strName,strShopName,strDescription,lngIndex
from? inserted

前觸發器和后觸發器簡介(downmoon)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 天天综合天天干 | 黄色成人影院 | 九九热亚洲精品综合视频 | 久久国产经典视频 | 色综合久久88色综合天天小说 | 久久婷婷激情 | 国产精品欧美一区二区三区 | 全部免费的毛片在线看青青 | 欧美老司机 | 欧美大片日韩精品四虎影视 | 中文不卡视频 | 国产免费一级高清淫日本片 | 在线婷婷| 今天的恋爱未删减在线观看 | 一级毛片a女人刺激视频免费 | 91精品国产色综合久久 | 奇米影视88888 | 91资源在线 | 日本综合在线观看 | 免费观看日本高清a毛片 | 国产精品国产色综合色 | 国产亚洲福利精品一区 | 精品久久不卡 | 免费国产黄线在线观看视频 | 亚洲一区免费视频 | 在线观看国产精品日本不卡网 | 亚洲国产经典 | 女人l8毛片a一级毛片免费 | 亚洲第3页| 国产成人精品免费视频网页大全 | 国内精品小视频在线 | 久久精品国产影库免费看 | 曰批免费视频播放在线看片 | 97国产在线公开免费观看 | 婷婷尹人香蕉久久天堂 | 色综合久久天天综合观看 | 久久―日本道色综合久久 | 久久久精品2021免费观看 | 黄色伊人网 | 九九热精品在线观看 | 亚洲精品免费在线视频 |