失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > sql server update触发器_SQL Server 触发器

sql server update触发器_SQL Server 触发器

时间:2021-10-13 11:07:47

相关推荐

sql server update触发器_SQL Server 触发器

T-SQL 触发器

触发器分为

BEFORE触发器*(SQL Server不支持,Oracle支持)在事件发生时触发。

AFTER触发器是SQLServer生成的最初用于自动相应数据修改的机制。在SQLServer200以前的版本中AFTER触发器是唯一的触发器,因此不用指明AFTER,也可以用FOR代替,该种触发器的行为是在事件之后执行

SQLServer2000中新增了INSTEAD OF触发器该触发器执行某项操作,而不是触发这个触发器的操作

AFTER触发器

AFTER触发器是默认的触发器类型,因此关键字AFTER可以选。

CREATE TRIGGER trigger_name

ON table_name

AFTER {INSERT | UPDATE | DELETE }

AS

BEGIN

-- SQL statement

END

GO

案例

在pubs数据库中生成一个触发器,打印一条消息,表示UPDATE Commands语句更新的数据行数。

USE pubs; -- 选择pubs数据库。

GO

CREATE TRIGGER tr_cmd_upd ON mands

AFTER UPDATE

AS

BEGIN

PRINT 'Trigger Output '+CONVERT(VARCHAR(5),@@ROWCOUNT)+' rows were updated.';

END

GO

-- 执行一条语句,查看触发器是否生效。

UPDATE mands

SET title=title

WHERE ID = 4;

GO

INSERTED表和DELETED表

在大多数触发器情况下,需要知道数据修改中发生了什么变化,可以在INSERTEDDELETED表中找到这个信息。

案例:

SELECT * INTO commands_copy FROM commands;

GO

CREATE TRIGGER tr_cc ON mands_copy

FOR INSERT, UPDATE, DELETE

AS

BEGIN

PRINT 'Inserted:';

SELECT ID, Type, Platform FROM INSERTED;

PRINT 'Deleted:';

SELECT ID, Type, Platform FROM DELETED;

END

检查列更新

INSERT或者UPDATE触发器内可以使用UPDATE()函数。

使用UPDATE()函数检查INSERTUPDATE操作对数据列的影响。

CREATE TRIGGER tr_ins_upd ON mands_copy

FOR INSERT, UPDATE

AS

BEGIN

IF(UPDATE(ID))

BEGIN

RAISERROR('You can not change the ID.', 15, 1);

END

END

执行

-[ ] 执行AFTER触发器之前发生的事件。

限制处理 -- 包括检查限制,唯一限制和主键限制。

声明式引用 -- 这些操作是外部键限制定义的,保证表间的正确关系。

触发操作 -- 即触发触发器的数据修改操作。这项操作发生在触发器执行之前,但结果要等到完成触发器操作之后才提交到数据库。

触发顺序

可以有多个对应于INSERTUPDATEDELETE的触发器,SQL Server可以指定第一个和最后一个触发器,但中间的触发器顺序则无法确定。

触发顺序

SP_SETTRIGGERORDER过程是设置触发器顺序的工具。

格式:

SP_SETTRIGGERORDER trigger_name, 顺序,'操作'./*其中,顺序为[First | Last | None] 操作为[Insert | Update | Delete]*/

例如:

SP_SETTRIGGERORDER tr_cmd_upd, FIRST, 'UPDATE';

建议尽量不要对同一个表的同一事件定义多个触发器,可以把相关的操作定义到一个触发器中。

特殊考虑

AFTER触发器可以用于具有级联参照完整性限制的表格中。

WRITETEXT与TRUNCATE TABLE不触发触发器。

触发器是对象,因此要在数据库中有唯一的名称。

AFTER触发器的限制

AFTER触发器只能用于表,不能用于视图。

一个AFTER触发器不能用在多个表上。

TEXT, NTEXT与IMAGE列不能引用AFTER触发器。

INSTEAD OF 触发器

SQL Server 2000引入新的Instead of 触发器。

Instead of 的含义:该触发器执行某项操作,而不是触发这个触发器的操作。

什么时候使用Instead of触发器。

3.1. 数据库里的数据禁止修改。

3.2. 有可能要回滚修改的SQL语句。

3.3. 在视图中使用的触发器,AFTER触发器不能在视图中使用。

3.4. 控制数据的修改方式和流程。

如果觉得《sql server update触发器_SQL Server 触发器》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。