【导图】
【内容】
1…什么是触发器
触发器是一个在修改指定表中的数据时执行的存储过程。经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业务规则,以此确保数据的完整性。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。
2.为什么要使用触发器?
触发器自动执行,它们在表的数据作了任何修改(比如手工输入或者使用程序采集的操作)之后立即激活。
触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更安全合理。
触发器可以强制限制,这些限制比用CKECK约束所定义的更复杂,与CHECK约束不同的是,触发器可以引用其他表中的列。
3.触发器种类
1)DDL触发器
DDL触发器当服务器或者数据库中发生数据定义语言(DDL事件时)将被调用。如果要执行以下操作,可以使用DDL触发器:
要防止对数据库架构进行某些更改;
希望数据库中发生某种情况以响应数据库架构中的更改
要记录数据库架构中的更改或者事件
2)DML触发器
DML触发器是当前数据库服务器中发生数据操作语言(DML)事件时要执行的操作,通常所说的DML触发器主要包括三种:INSERT触发器、UPDATE触发器、DELETE触发器。DML触发器可以查询其他表,还可以包含复杂的T-SQL语句。将触发器和触发它的语句作为可在触发器内回滚的单个事务对待。如果检测到错误,则整个事务自动回滚。
4.创建INSERT触发器
CREATE TRIGGER trigger_name
On+表或者视图
{
For\after\instead of
Delete,insert,update
As
Sql_statement
}
举例:
select 班级人数 from 班级信息 where 班级编号='101'
insert into 学生信息 values('1258963','王俊','女','1986-01-16','101','河北省廊坊市安次区')
select 班级人数 from 班级信息 where 班级编号='101'
5.创建DELETE触发器
Create trigger t_deleteteacher
On 教师信息
For delete
As
Select 姓名 as 被删除的教师姓名,性别,年龄,联系电话 from deleted
触发:
Delete from 教师信息 where 教师编号='2005001'
6.创建update触发器
create trigger t_update
on 教师信息
for update
as
if(update(姓名)or update(性别))
begin
print'事务不能被处理,基础数据不能修改!'
rollback transaction
end
else
print'数据修改成功!'
7.创建DDL触发器
Create trigger trigger_name
On all server|detabase
With encryption(是否加密)
For |after{event_type}
As
Sql_statement
举例:
create trigger t_notdelete
on database
for drop_table,alter_table
as
print'事务不能被处理,基础数据表不能被修改和删除!'
rollback
8.递归触发器
任何触发器都可以包含影响同一个表或另一个表的UPDATE、INSERT或DELETE语句。如果启用递归触发器选项,那么改变表中数据的触发器,通过递归执行就可以再次触发自己。在数据库创建时,默认情况下递归触发器选项是禁用的,但可以使用ALTER DATABASE语句来启用它。
注意!!!
递归触发器具有复杂特性,可以用它来解决诸如自引用关系这样的复杂关系。使用递归触发器时,需要考虑以下的事项和原则:
递归触发器很复杂,必须经过有条理的设计和全面的测试。
在任意点的数据修改会触发一系列触发器。尽管提供处理复杂关系的能力,但是如果要求以特定的顺序更新用户的表时,使用递归触发器就会产生问题。
所有触发器一起构成一个大事务,任何触发器中的任何位置上的OROLLBACK命令都将取消所有的数据输入。所有数据均被擦除,并且无任何数据被放到表中。
触发器最多只能递归16层。换句话说,如果递归链中的第16个触发器激活了第17个触发器,则结果与发布ROLLBACK命令一样,所有数据将被擦除。