服务器之家:专注于服务器技术及软件下载分享
分类导航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|数据库技术|

服务器之家 - 数据库 - Sql Server - sql 触发器使用例子

sql 触发器使用例子

2019-11-11 15:13mssql教程网 Sql Server

触发器里没有updated ,只有inserted 和deleted两个临时表。

inserted,deleted是在触发器中使用的两个临时表,当执行insert操作时,在inserted中存储着当前插入的记录,在执行delete操作时,在deleted中存储着当前删除的记录,当执行update时,在inserted中存储着修改后的记录,在deleted中存储着修改前的记录。

复制代码代码如下:


set ANSI_NULLS ON 
set QUOTED_IDENTIFIER ON 
go 

ALTER TRIGGER [dnt_user_add] 
ON [dbo].[dnt_users] 
AFTER INSERT 
AS 
BEGIN 
SET NOCOUNT ON; 
insert into [dnt_userfields](uid) 
select uid from inserted 

END 



删除: 

复制代码代码如下:


SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 

CREATE TRIGGER [dnt_users_del] 
ON [dnt_users] 
AFTER DELETE 
AS 
BEGIN 

SET NOCOUNT ON; 
delete [dnt_userfields] from deleted where [dnt_userfields].uid=deleted.uid 

END 
GO 


修改:

复制代码代码如下:


SET ANSI_NULLS ON 
GO 
SET QUOTED_IDENTIFIER ON 
GO 

ALTER TRIGGER [dnt_users_up] 
ON [dnt_users] 
AFTER UPDATE 
AS 
BEGIN 

SET NOCOUNT ON; 
UPDATE [dnt_userfields] Set icq = inserted.uid from inserted where [dnt_userfields].uid = inserted.uid 

END 
GO 

延伸 · 阅读

精彩推荐