在SQL Server 2008中,设表T(a,b)上建有如下触发器: CREATE TRIGGER tri_update ON T FOR UPDATE AS IF EXISTS(SELECT*FROM inserted

admin2020-08-01  12

问题 在SQL Server 2008中,设表T(a,b)上建有如下触发器:
CREATE TRIGGER tri_update ON T FOR UPDATE AS
   IF EXISTS(SELECT*FROM inserted
             WHERE b not between 0 and 100)
   ROLLBACK
设表T中已有数据:(′a01′,90),如果执行语句:
UPDATE T SET b=100 WHERE a=′a01′
则触发器临时工作表及执行完该语句后表T中的数据为(    )。

选项 A、T表:(′a01′,100)  
INSERTED表:(′a01′,90)  
DELETED表:(′a01′,100)  
B、T表:(′a01′,90)  
INSERTED表:(′a01′,90)  
DELETED表:(′a01′,100)  
C、T表:(′a01′,100)  
INSERTED表:(′a01′,100)  
DELETED表:(′a01′,90)  
D、T表:(′a01′,90)  
INSERTED表:(′a01′,100)  
DELETED表:(′a01′,90)  

答案C

解析 用FOR关键字定义的触发器为后触发型触发器,即只有在引发触发器执行的语句中指定的操作都已成功执行,并且所有的约束检查也成功完成后才执行触发器。其中INSERTED表用于存储INSERT和UPDATE语句所影响行的新值的副本,DELETED表用于存储DELETE和UPDATE语句所影响行的旧值的副本。在执行“UPDATE T SET b=100 WHERE a=′a01′”之后,T表为:(′a01′,100),INSERTED表内容变为:(′a01′,100),DELETED表内容变为:(′a01′,90)。继续判断约束检查“SELECT*FROM inserted WHERE b not between 0 and 100”,因为INSERTED表中的b等于100,因此约束不成立,故触发器不执行。
转载请注明原文地址:https://kaotiyun.com/show/93lZ777K
0

最新回复(0)