Sql Server觸發器的使用

2022-09-24 22:57:12 字數 1780 閱讀 6104

sql serefesqoxsver為每個觸發器都建立了兩個專用表:inserted表和deleted表。這兩個表由系統來維護,它們存在於記憶體中而不是資料庫中。這兩個表的結構總是與被該觸發器作用的表的結構相同,觸發器執行完成後,與該觸發器相關的這兩個表也被刪除。 

對錶的操作

inserted邏輯表

deleted邏輯表

增加記錄(insert)

存放增加的記錄

無刪除記錄(delete)

無存放被刪除的記錄

修改記錄(update)

存放更新後的記錄

存放更新前的記錄

三、for、after、instead of觸發器

after:觸發器在觸發它們的語句efesqoxs完成後執行。如果該語句因錯誤而失敗,觸發器將不會執行。不能為檢視指定after觸發器,只能為表指定該觸發器。可以為每個觸發操作(insert、update、delete)指定多個after觸發器。如果表有多個after觸發器,可使用sp_settriggerorder定義哪個after觸發器最先激發,哪個最後激發。除第乙個和最後乙個觸發器外,所有其他的after觸發器的激發順序不確定,並且無法控制。

for:等同於after

instead of:該觸發器代替觸發操作執行。可在表和檢視上指定instead of觸發器。只能為每個觸發操作(insert、update、delete)定義乙個instead of觸發器。instead of觸發器可用於對insert和update語句中提供的資料值執行增強的完整性檢查。

四、 觸發器的使用

1、建立觸發器:

create trigger trigger_name

on  

[ insert, update,delete ]

assql_statement 

2、刪除觸發器:

drop trigger trigger_name 

3、檢視資料庫中已有的觸發器:

select * from sysobjects where xtype='tr'

4、檢視單個觸發器:

exec sp_helptext '觸發器名' 

5、修改觸發器:

alter trigger trigger_name

on  

[ insert, update,delete ]

as sql_statement

五、觸發器的例項

1、在orders表中建立觸發器,當向orders表中插入一條記錄時,檢查goods表的貨品狀態status是否為1。是,則不能往orders表加入該訂單。

if (object_id('tgr_', 'tr') is not null)

drop trigger [tgr_orders_insert];

gocreate trigger [tgrwww.cppcns.com_orders_insert]

on [orders]

after insert

as if (select [status] from [goods],[inswww.cppcns.comerted] where [goods].name=[inserted].name)=1

begin

print 'the goods is being processed'

print 'the order cannot be committed'    

rollback transaction   --回滾﹐避免加入

end 

本文標題: sql server觸發器的使用

本文位址:

SqlServer觸發器的使用

首先 說明乙個觸發器使用的場景。1.伺服器0001上的employee表負責儲存公司所有員工的最新資料,新員工入職 員工更換部門以及員工離職等資訊都存在該表中。2.由於業務需求,公司新上了乙個oa系統,為了確保系統正常平穩執行且不影響公司其他伺服器,所以oa系統就部署在了0002伺服器上。3.oa系...

SQL Server觸發器的使用

1.定義 觸發器 trigger 是sql server 提供給程式設計師和資料分析員來保證資料完整性的一種方法,它是與表事件相關的特殊的儲存過程,它的執行不是由程式呼叫,也不是手工啟動,而是由事件來觸發,比如當對乙個表進行操作 insert,delete,update 時就會啟用它執行。觸發器經常...

SQLServer觸發器的使用

觸發器建立的 create trigger tg projectname ontable1 after update asupdatetable2 set 工程名 b.工程名 from table2 a,inserted b where a.projid b.id 關於觸發器中inserted和de...