在mssql中,使用触发器有一定的好处,比如同步更新数据到某个表等,不过触发器不能使用过多,会造成性能上的影响,这方面的影响还挺大,如果有一个上百万记录的表,不推荐使用触发器,下面我们来看下使用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

 

应用二、更新记录触发器

代码
/***************************************

检测更新的触发器,当有用户修改了自己的密码,
会将用户的信息拷入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

 

应用三、删除记录触发器

代码
/***************************************

检测删除的触发器,当用户被删除时,
会将用户的信息拷入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

 

相关文章:

  • 2021-09-29
  • 2021-08-02
  • 2022-12-23
  • 2022-12-23
  • 2021-09-25
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-02-08
  • 2022-12-23
  • 2022-12-23
  • 2021-10-18
  • 2021-09-28
相关资源
相似解决方案