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

我們知道,觸發器是一種特殊的存儲過程。當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

sql server 2000中的觸發器使用
觸發器是數據庫應用中的重用工具,它的應用很廣泛。   1. insert觸發器的工作過程 可以定義一個無論何時用INSERT語句向表中插入數據時都會執行的觸發器。 當觸發INSERT觸發器時,新的數據行就會被插入到...查看完整版>>sql server 2000中的觸發器使用
 
SQL Server 2000中的觸發器使用
  觸發器是數據庫應用中的重用工具,它的應用很廣泛。這幾天寫一個化學數據統計方面的軟件,需要根據采樣,自動計算方差,在這裏,我使用了觸發器。  下面我摘錄了SQL Server官方教程中的一段關于觸發器的文字,...查看完整版>>SQL Server 2000中的觸發器使用
 
如何在sql sever 2000 更改所有表的所有者
...查看完整版>>如何在sql sever 2000 更改所有表的所有者
 
SQL Sever 2000的系統數據庫和索引
SQL Sever 2000的系統數據庫和索引 學習人:HSLY 學習書籍:SQL Server 2000入門與提高 撰寫日期:2004-7-12 章節:4.1 P44 9.6.1P126 SQL Server 2000 在安裝過程中,創建了4個系統數據庫,這4個系統數據庫是...查看完整版>>SQL Sever 2000的系統數據庫和索引
 
SQL SERVER 2000 中的標識值獲取函數
IDENTITY(標識)列,也有很多人稱之爲自增列,在SQL Server 2000中,標識列通過IDENTITY來定義,下面是與獲取最後插入記錄的標識值有關的函數的一個示例說明 SQL Server 中,可以使用 SCOPE_IDENTITY()、 @@IDE...查看完整版>>SQL SERVER 2000 中的標識值獲取函數
 
SQL SERVER 2000 中的標識值獲取函數
SQL SERVER 2000 中的標識值獲取函數 IDENTITY(標識)列,也有很多人稱之爲自增列,在SQL Server 2000中,標識列通過IDENTITY來定義,下面是與獲取最後插入記錄的標識值有關的函數的一個示例說明 SQL Server 中...查看完整版>>SQL SERVER 2000 中的標識值獲取函數
 
SQL SERVER 2000 中的標識值獲取函數
SQL SERVER 2000 中的標識值獲取函數 IDENTITY(標識)列,也有很多人稱之爲自增列,在SQL Server 2000中,標識列通過IDENTITY來定義,下面是與獲取最後插入記錄的標識值有關的函數的一個示例說明 SQL Server 中...查看完整版>>SQL SERVER 2000 中的標識值獲取函數
 
SQL Server 2000中的數據存儲形式(二)
SQL Server 是一個關系數據庫管理系統,它最初是由Microsoft 、Sybase 和Ashton-Tate三家公司共同開發的,于1988 年推出了第一個OS/2 版本。在Windows NT 推出後Microsoft與Sybase 在SQL Server 的開發上就分道揚镳了...查看完整版>>SQL Server 2000中的數據存儲形式(二)
 
如何解決 SQL Server 2000 中的連接問題
如何解決 SQL Server 2000 中的連接問題 重要說明:本文包含有關修改注冊表的信息。修改注冊表之前,一定要備份注冊表,並且一定要知道在發生問題時如何還原注冊表。有關如何備份、還原和編輯注冊表的信息,請單擊下...查看完整版>>如何解決 SQL Server 2000 中的連接問題
 
 
回到王朝網路移動版首頁