先抄一点关于触发器的文字介绍,后边谈我自己的例子:

在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
常见的有三种:分别应用于Insert , Update , Delete 事件。

一、Trigger语法:
create trigger tr_name
on table/view
{for | after | instead of } [update][,][insert][,][delete]
[with encryption]
as {batch | if update (col_name) [{and|or} update (col_name)] }

说明:
1 tr_name :名称
2 on table/view :触发器所作用的表。一个触发器只能作用于一个表
3 for 和after :同义
4 after 与instead of :sql 2000新增项目afrer 与 instead of 的区别
After
在触发事件发生以后才被激活,只可以建立在表上
Instead of
代替了相应的触发事件而被执行,既可以建立在表上也可以建立在视图上
5 insert、update、delete:激活触发器的三种操作,可以同时执行,也可选其一
6 if update (col_name):表明所作的操作对指定列是否有影响,有影响,则激活触发器。此外,因为delete 操作只对行有影响,
所以如果使用delete操作就不能用这条语句了(虽然使用也不出错,但是不能激活触发器,没意义)。
7 触发器执行时用到的两个特殊表:deleted ,inserted
deleted 和inserted 可以说是一种特殊的临时表,是在进行激活触发器时由系统自动生成的,其结构与触发器作用的表结构是一
样的,只是存放 的数据有差异。

下面谈一点心得:
触发器的使用有两个关键点,一是触发器的逻辑,即触发器的设计问题,二是两张临时表deleted和inserted。
谈谈我写的这个例子的背景,两张表,一张为评价标准,存放的各种各样的标准,权值,评分,一张为数据,我的工作是根据数据对照标准来进行评分。现在有一个很现实的问题,就是当标准的表被修改时,数据表要有相应的改动,我在这个问题上采用了触发器。

USE [EvaluateSystem]
GO
Create trigger [dbo].[AddDataColumn]
on [dbo].[EvaluateHierarchy]
after insert
as
declare @s varchar(50)
declare @n int
declare @sql NVARCHAR(539)
begin
select @s=TwoLevelStandard from inserted i
select @n=COUNT(*) from EvaluateHierarchy 
where TwoLevelStandard=@s
if(@n=1)
begin
SET @sql = N'alter table [dbo].[EvaluateData] add '+ @s+ ' varchar(50) null'  + N';'  
exec(@sql)
end
end

这个应该都能看懂,我说说自己觉得困难的地方
1.对于变量的使用,就是@s这里,变量的赋值的方式是没用过的(t-sql并不会)
2.要用exec来执行sql语句,我本意是把

alter table [dbo].[EvaluateData] add '+ @s+ ' varchar(50) null
这一句直接写在这个触发器中,等待顺序执行,调了半天并没有用,还一直报错,后来发现要用exec来执行

3.exec执行动态sql语句时不能执行这种语句

exec('alter table [dbo].[EvaluateData] add '+ @s+ ' varchar(50) null' )
但是可以执行这种语句(这个细节折磨了我半天)
exec(@sql)

4.触发器的调试,这个玩意因为是个后台被动触发,所以要执行相应的语句才能进入,即单步调试(f10)一个插入语句,执行到insert时F11进入就可以了