撤销单个UPDATE语句是否造成数据损失?

在论坛看到有人执行了一个UPDATE,但是发现错了,问是否可以取消这个更新操作。因为涉及的数据比较多,所以怕取消操作造成数据不一致。

 

其实对于单独的UPDATE操作而言,都是当做一个隐性事务处理的,具有ACID属性,Non或者All.所以不管这个UPDATE会影响多少行,取消操作所有影响的行都会回滚,保证事务完整性。

 

下面的解释来自SQL SERVER 2008 INTERNALS:

 

An implicit transaction is any individual INSERT, UPDATE, DELETE, or MERGE statement. (You can also consider SELECT statements to be implicit transactions, although SQL Server does not write to the log when SELECT statements are processed.) No matter how many rows are affected, the statement must exhibit all the ACID properties of a transaction。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值