sql server添加、更新、删除触发器的例子

发布时间:2019-11-28编辑:脚本学堂
本文介绍下,在sql server中添加、更新与删除触发器的例子,有意研究sql server触发器的朋友,可以参考学习下。

在sql server中,使用触发器大有益处:
比如同步更新数据到某个表等。

不过,在数据量非常大时,建议不要使用触发器,因为会带来严重的性能损失。

下面我们学习下使用sql触发器的应用。
主要包括:
 

inserted 一个是deleted
inserted表示insert或update的新值集合
deleted 是update时的旧值或要删除的值集合

例1:插入记录触发器
 

复制代码 代码示例:
/***
检测插入的触发器,当新建用户时,
会将用户的信息拷入ZWUserSysc以便同步
****/
CREATE TRIGGER Trg_ZWTLog_Insert
ON [DN_user]
for Insert 
AS
begin
declare @id varchar(50)
declare @Name varchar(50)
declare @LogonName varchar(50)
declare @Password varchar(50)
 
select @id=id, @Name=name,@LogonName=LogonNm, @password=password from  inserted
insert into ZWUserSysc (ID,Name,LogonNm,Password,status) values (@id,@Name,@LogonName,@password,'I')
end

例2,更新记录触发器
 

复制代码 代码示例:
/***
检测更新的触发器,当有用户修改了自己的密码,
会将用户的信息拷入ZWUserSysc以便同步
 ***/
CREATE TRIGGER Trg_ZWTLog_UPDATE
ON [DN_user]
for UPDATE 
AS
begin
declare @id varchar(50)
declare @Name varchar(50)
declare @LogonName varchar(50)
declare @Password varchar(50)
 
select @id=id, @Name=name,@LogonName=LogonNm, @password=password from  inserted
insert into ZWUserSysc (ID,Name,LogonNm,Password,status) values (@id,@Name,@LogonName,@password,'U')
end
GO

例3,删除记录触发器
 

复制代码 代码示例:

/***
检测删除的触发器,当用户被删除时,
会将用户的信息拷入ZWUserSysc以便同步
***/
CREATE TRIGGER Trg_ZWTLog_Delete
ON [DN_user]
for Delete 
AS
begin
declare @id varchar(50)
declare @Name varchar(50)
declare @LogonName varchar(50)
declare @Password varchar(50)

select @id=id, @Name=name,@LogonName=LogonNm, @password=password from  Deleted
insert into ZWUserSysc (ID,Name,LogonNm,Password,status) values (@id,@Name,@LogonName,@password,'D')
end
GO