SQL触发器中,系统自动会生成两张临时表,分别是deleted 和 inserted
它们是逻辑(概念)表。也可理解为是临时表。
Inserted表就是放新的记录,Delete表就是放旧的记录。
并且,它们的表结构与原表是完全相同的。
当插入时,要插入的记录是新的,所以可以在Insert表中找到。
当更新时,要更新的记录是新的,所以可以在Inserted表中找到,被更新的记录是旧的,所以可以在Deleted表中找到。
当删除时,要删除的记录是旧的,所以可以在Deleted表中找到。
格式:
CREATE TRIGGER trigger_name
ON { table | view }
[ WITH ENCRYPTION ] --用于加密触发器
{
{ { FOR | AFTER | INSTEAD OF } { [ INSERT ] [ , ] [ UPDATE ] }
[ WITH APPEND ]
[ NOT FOR REPLICATION ]
AS
[ { IF UPDATE ( column )
[ { AND | OR } UPDATE ( column ) ]
[ ...n ]
| IF ( COLUMNS_UPDATED ( ) { bitwise_operator } updated_bitmask )
{ comparison_operator } column_bitmask [ ...n ]
} ]
sql_statement [ ...n ]
}
}
例子:
CREATE TRIGGER DepartLevelTriggerXieYi
ON app_DepartLevel
FOR INSERT
AS
DECLARE @UpLevelCompCode VARCHAR(50)
DECLARE @UpLevelCompName VARCHAR(50)
DECLARE @CurrentLevelCompCode VARCHAR(50)
DECLARE @CurrentLevel VARCHAR(50)
BEGIN
SET @CurrentLevel=(SELECT CurrentLevel FROM INSERTED)
IF(LEN(@CurrentLevel)=6)
BEGIN
SET @UpLevelCompCode=(SELECT UpLevelCompCode FROM INSERTED)
SET @UpLevelCompName=(SELECT UpLevelCompName FROM INSERTED)
SET @CurrentLevelCompCode=(SELECT CurrentLevelCompCode FROM INSERTED)
UPDATE SP_FL_FanLiXieYiGuanLi SET UpLevelCompCode = @UpLevelCompCode,UpLevelCompName = @UpLevelCompName
WHERE CompanyOfServer=@CurrentLevelCompCode
END
END
8989

被折叠的 条评论
为什么被折叠?



