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

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

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

    Junky's IT Notebook

    統計

    留言簿(8)

    積分與排名

    WebSphere Studio

    閱讀排行榜

    評論排行榜

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

    前觸發器和后觸發器簡介(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

    posted on 2007-06-19 09:35 junky 閱讀(320) 評論(0)  編輯  收藏 所屬分類: SQL Server

    主站蜘蛛池模板: 亚洲成人黄色在线观看| 永久免费观看的毛片的网站| 伊人久久大香线蕉亚洲| 一级看片免费视频| 国产成人免费全部网站| 日韩色日韩视频亚洲网站| 日韩伦理片电影在线免费观看| 亚洲专区中文字幕| 在线免费观看色片| 午夜亚洲国产精品福利| 亚洲精品国产电影| 99re6在线视频精品免费| 国产精品亚洲成在人线| 两个人看的www免费高清| 伊人久久大香线蕉亚洲五月天| 99免费在线视频| 亚洲国产精品第一区二区| 最近2019中文字幕免费大全5| 麻豆亚洲av熟女国产一区二| 无码人妻一区二区三区免费手机 | 美女被cao免费看在线看网站| 亚洲色大成网站www永久| 久久精品免费全国观看国产| 亚洲AV成人片无码网站| 国产91精品一区二区麻豆亚洲| 精品视频在线免费观看| 亚洲资源在线视频| 在人线av无码免费高潮喷水| 亚洲欧美在线x视频| 国产精品亚洲片在线| 99热精品在线免费观看| 亚洲精品亚洲人成在线观看| 亚洲成人免费电影| 亚洲国产精品专区在线观看| 好久久免费视频高清| 亚洲人成无码网站在线观看| 中文字幕亚洲无线码| 黄瓜视频影院在线观看免费| 欧洲美女大片免费播放器视频| 亚洲国产精品嫩草影院在线观看 | 狠狠综合久久综合88亚洲|