在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