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

本文讨论了在执行UPDATE操作后如何进行撤销的问题。指出每个UPDATE操作都作为一个隐性事务处理,具有ACID属性,确保数据一致性。即使影响大量数据,取消操作也能保证所有受影响的数据行回滚。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在论坛看到有人执行了一个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、付费专栏及课程。

余额充值