设为首页 加入收藏

TOP

数据库触发器小结
2014-11-24 03:31:10 来源: 作者: 【 】 浏览:1
Tags:数据库 触发器 小结
数据库触发器小结

触发器的概念、分类与作用
触发器是一种特殊类型的存储过程。
触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。
触发器有4个要素:
名称:触发器有一个符合标志符命名规则的名称。
定义的目标:触发器必须定义在表或者视图上。
触发条件:是UPDATE、INSERT还是DELETE语句。
触发逻辑:触发之后如何处理。

触发器的种类
AFTER触发器
AFTER触发器是告诉SQL语句执行了INSERT、UPDATE或者DELETE操作后干什么。
INSTEAD OF触发器
告诉当要执行INSERT、UPDATE或DELETE操作时用什么别的操作来代替。
触发器的作用
强化约束:触发器能够实现比CHECK约束更为复杂的约束
跟踪变化:触发器可以侦测数据库内的操作,从而不允许数据库中未经许可的变化。
级联运行
存储过程的调用
触发器的工作原理

SQL Server在工作时为每个触发器在服务器的内存上建立两个特殊的表:插入表和删除表。
(1) 插入表的功能
一旦对该表执行了插入(INSERT)操作,那么对该表插入的所有行来说,都有一个相应的副本存放到Inserted表中,即Inserted表用来存储原表插入的内容。
(2)删除表的功能
一旦对该表执行了删除(DELETE)操作,则将所有的删除行存放至Deleted表中。这样做的目的是,一旦触发器遇到了强迫它中止的语句被执行时,删除的那些行可以从Deleted表中得以还原。
创建触发器
在创建触发器以前必须考虑到以下几个方面:
CREATE TRIGGER语句必须是批处理的第一个语句。
表的所有者具有创建触发器的缺省权限,表的所有者不能把该权限传给其他用户。
触发器是数据库对象,所以其命名必须符合命名规则。
尽管在触发器的SQL语句中可以参照其他数据库中的对象,但是触发器只能创建在当前数据库中。
虽然触发器可以参照视图或临时表,但不能在视图或临时表上创建触发器,只能在基表或在创建视图的表上创建触发器。
一个触发器只能对应一个表,这是由触发器的机制决定的。

[例] 创建一个触发器,当向S表中插入一条记录时,自动显示S表中的记录。

CREATE TRIGGER ChangeDisplay
ON S
FOR INSERT
AS
SELECT * FROM S
查看触发器
使用 系统存储过程查看触发器
EXEC sp_help '触发器名'
了解触发器的一般信息,如触发器的名字、属性、类型、创建时间

EXEC sp_helptext '触发器名'
查看触发器的正文信息

EXEC sp_depends '触发器名'
EXEC sp_depends '表名 '
查看指定触发器所引用的表或指定的表所涉及到的所有触发器
修改触发器
使用sp_rename修改触发器的名字
sp_rename oldname,newname

删除触发器
用系统命令DROP TRIGGER删除指定的触发器
DROP TRIGGER 触发器名
注:删除触发器所在的表时,SQL Server将自动删除与该表相关的触发器。

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇数据库中的事务、存储过程和触发.. 下一篇触发器实现表数据自动更新

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·数据库:推荐几款 Re (2025-12-25 12:17:11)
·如何最简单、通俗地 (2025-12-25 12:17:09)
·什么是Redis?为什么 (2025-12-25 12:17:06)
·对于一个想入坑Linux (2025-12-25 11:49:07)
·Linux 怎么读? (2025-12-25 11:49:04)