<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 189,comments - 115,trackbacks - 0
    前觸發(fā)器和后觸發(fā)器簡介(downmoon)

    ??? 觸發(fā)器是一種特殊的存儲過程。當Insert Update 或者Delete 語句修改表中一個或者多個行時執(zhí)行觸發(fā)器。因為SQL Server 對特定表上的每一個指定操作調(diào)用一個觸發(fā)器,所以可以使用觸發(fā)器擴展SQL Sever 的內(nèi)置完整性和數(shù)據(jù)操縱功能.
    ??? 注意:不像Delete 語句,Trancate Table 語句不激活觸發(fā)器,Write Text 語句也不激活觸發(fā)器。
    ??? 在SQL Sever 2000 中支持兩種類型的觸發(fā)器,前觸發(fā)器(Instead Of Trigger)和后觸發(fā)器(After Trigger)。前觸發(fā)器就是在語句執(zhí)行之前激活觸發(fā)器,而后觸發(fā)器就是在語句執(zhí)行之后激活觸發(fā)器。可以通過FOR 子句來選擇使用何種觸發(fā)器。
    ??? 當為每一種操作創(chuàng)建一個觸發(fā)器時,可以為所有三種操作創(chuàng)建一個觸發(fā)器,并且使用相應(yīng)的編程技術(shù)處理每一種操作。下面的示例在For 子句中列出了三種語句類型并,且使用條件語句將相應(yīng)的跟蹤值插入到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 臨時表有新行。這個示例還反映了觸發(fā)器的另一個重要方面:對于某個表的Update 或者Delete 操作,即使該語句沒有影響到行,也激活觸發(fā)器 (也就是說沒有滿足Where 子句的行)。 觸發(fā)器的存儲過程應(yīng)該預測這種可能性。


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

    ??? 盡管觸發(fā)器是一種存儲過程,但是不能使用Execute 語句調(diào)用它,如果有希望共享觸發(fā)器和正常的存儲過程的編碼,那么只需把共享代碼放在存儲過程中,從觸發(fā)器中調(diào)用它。如果一個觸發(fā)器修改一個表,那么這些修改可能會激活另一個觸發(fā)器,或者本身。在默認情況下,SQL Sever 允許這種嵌套的觸發(fā)器調(diào)用深度為32層。雖然我們建議允許嵌套的和疊代的觸發(fā)器,但是可以使用系統(tǒng)存儲過程禁止這么做。下面的語句在指定的數(shù)據(jù)庫上防止疊代觸發(fā)器:
    sp_dboption AppDta,`recursive triggers',`false'
    ??? 為了在所有數(shù)據(jù)庫中防止嵌套觸發(fā)器調(diào)用(包括疊代調(diào)用),可以使用下面的語句:
    sp_configure `nested triggers',0

    ??? 前面以后觸發(fā)器為例介紹了觸發(fā)器的基本內(nèi)容,下面再介紹一下前觸發(fā)器的不同之處。要創(chuàng)建一個前觸發(fā)器必須用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
    ??? 與后觸發(fā)器不同的是:前觸發(fā)器既可以在表又可以在視圖上創(chuàng)建,但一條語句只能創(chuàng)建一個前觸發(fā)器,因此,前觸發(fā)器不存在激活順序問題


    觸發(fā)器應(yīng)用舉例:從當前數(shù)據(jù)庫服務(wù)器的Shop表Insert操作同步到另一臺服務(wù)器的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

    作者Blog: http://blog.csdn.net/downmoon/
    posted on 2006-04-07 21:38 MEYE 閱讀(589) 評論(0)  編輯  收藏 所屬分類: Study
    主站蜘蛛池模板: 国产成在线观看免费视频| 亚洲影视自拍揄拍愉拍| 国产成人免费福利网站| 99在线观看视频免费| 黄色网址免费在线观看| 精品无码专区亚洲| 亚洲精品福利你懂| 久久水蜜桃亚洲av无码精品麻豆| 亚洲精品国产高清嫩草影院| 成年女人视频网站免费m| 又大又硬又爽又粗又快的视频免费| 国产99精品一区二区三区免费| 亚洲a∨国产av综合av下载| 亚洲一卡2卡3卡4卡国产网站| 亚洲国产精品一区| 亚洲无线观看国产精品| 亚洲精品A在线观看| 啊v在线免费观看| 日本免费高清一本视频| 午夜a级成人免费毛片| 很黄很色很刺激的视频免费| 最近中文字幕免费mv在线视频| 免费毛片a线观看| 免费人成网站在线观看不卡| 免费高清国产视频| 免费看搞黄视频网站| 久久大香香蕉国产免费网站| 老司机69精品成免费视频| a毛片全部免费播放| a毛片在线看片免费| 久久99热精品免费观看牛牛| 国产99视频精品免费专区| 久久久久久免费一区二区三区| 抽搐一进一出gif免费视频| 91在线免费观看| 免费看一区二区三区四区| 日韩精品免费视频| 3d成人免费动漫在线观看 | 亚洲国产高清精品线久久| 高清在线亚洲精品国产二区| av无码东京热亚洲男人的天堂|