在SqlServer中自动ID可以说很重要,如果没有它,可能有的功能就难以实现。用select C1 from Deleted 这样的语句做赋值做比较,一般情况下,如果是单独触发,都是得到单个值,这时候是没问题的。但如果多个关系表级联触发或者其它更新语句间接触发更新数据,就会出错,说什么子查询不能用在=、>、<、<>等运算中。因为此时得到的是理论上是多条记录,是一个数据集,自然就不能像单个值那样运算了。为此可以用下面的方法解决。有表Table1,Table2,Table3。Table1触发Table2用T1,Table2触发Table3用T2。
T1:update Table2 set C1=(select a from Inserted) from Table2 join Deleted on Table2.C1=Deleted.a
T2:--update A set a=(select C1 from Inserted) from Table3 A join Deleted D on A.a=D.C1 and A.b=D.C2
--update A set b=(select C2 from Inserted) from Table3 A join Deleted D on A.a=D.C1 and A.b=D.C2
--if (select C1 from Inserted)<>(select C1 from Deleted) --问题之所在,如果得到的结果是多条就出错,级联触发就会产生多记录,必定出错。
--如下两种方法都可以,不要用 select C1 from Deleted 这样的
update A set a=I.C1,b=I.C2 from Table3 A join Deleted D on A.a=D.C1 and A.b=D.C2 join Inserted I on D.ID=I.ID and (I.C1<>D.C1 or I.C2<>D.C2)
--select D.C1,D.C2,I.C1 C1_New,I.C2 C2_New into #Edit from Inserted I join Deleted D on I.ID=D.ID and (I.C1<>D.C1 or I.C2<>D.C2)
--if (select count(*) from #Edit)>0
--update A set a=#Edit.C1_New,b=#Edit.C2_New from Table3 A join #Edit on A.a=#Edit.C1 and A.b=#Edit.C2
以后触发器中就不要用select C1 from Deleted 这种形式的写法了,即使不是级联触发也不用,如果用Update语句还是会引起这种问题。
与此同时,在上面的写法中都有一个自动增量的唯一的不可修改的ID,用于确定Deleted和Inserted的关联,否则无法关联。