好儿郎-志在四方 2015-09-08 08:44 采纳率: 100%
浏览 1804
已采纳

数据库、触发器、三级数据库选择题,求大神解答

(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)
敲字不容易呀,麻烦各位大神解答一下,详细点更好,多谢了

  • 写回答

1条回答 默认 最新

  • threenewbee 2015-09-08 08:47
    关注
     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 o and l00”,因为INSERTED表中的b等于l00,因此约束不成立,故触发器不执行。
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 TMC2209串口模式下读取不到寄存器的值串口助手蓝色字体是发过去的消息,绿色字体是收到的消息,第二行发送读取寄存器的指令但是没有读取到寄存器的值串口助手如下图:接线如下图,如何解决?
  • ¥15 高通安卓11提取完整线刷包软件,或者优博讯dt50顺丰刷机包
  • ¥20 C,有个译码器,换了信道就跑不出原来数据
  • ¥15 MIMIC数据库安装问题
  • ¥60 基于JTag协议开发Fpga下载器上位机,哪位大🐂有偿指导?
  • ¥20 全书网Java爬取数据
  • ¥15 怎么获取红包封面的原始链接,并且获取红包封面序列号
  • ¥100 微信小程序跑脚本授权的问题
  • ¥100 房产抖音小程序苹果搜不到安卓可以付费悬赏
  • ¥15 STM32串口接收问题