Sql Server為每個觸發器都建立了兩個專用表:Inserted表和Deleted表。這兩個表由系統來維護,它們存在於記憶體中而不是資料庫中。這兩個表的結構總是與被該觸發器作用的表的結構相同,觸發器執行完成後,與該觸發器相關的這兩個表也被刪除。
對錶的操作 |
Inserted邏輯表 |
Deleted邏輯表 |
增加記錄(insert) |
存放增加的記錄 |
無 |
刪除記錄(delete) |
無 |
存放被刪除的記錄 |
修改記錄(update) |
存放更新後的記錄 |
存放更新前的記錄 |
三、for、after、instead of觸發器
after:觸發器在觸發它們的陳述式完成後執行。如果該語句因錯誤而失敗,觸發器將不會執行。不能為視圖指定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 {table_name | view_name}
{for| After | Instead of }
[ insert, update,delete ]
as
sql_statement
2、刪除觸發器:
drop trigger trigger_name
3、查看資料庫中已有的觸發器:
select * from sysobjects where xtype='TR'
4、查看單個觸發器:
exec sp_helptext '觸發器名'
5、修改觸發器:
alter trigger trigger_name
on {table_name | view_name}
{for| After | Instead of }
[ insert, update,delete ]
as
sql_statement
五、觸發器的執行個體
1、在Orders表中建立觸發器,當向Orders表中插入一條記錄時,檢查goods表的貨品狀態status是否為1。是,則不能往Orders表加入該訂單。
if (object_id('tgr_orders_insert', 'tr') is not null)
drop trigger [tgr_orders_insert];
go
create trigger [tgr_orders_insert]
on [orders]
after insert
as
if (select [status] from [goods],[inserted] where [goods].name=[inserted].name)=1
begin
print 'the goods is being processed'
print 'the order cannot be committed'
rollback transaction --復原﹐避免加入
end