
sql server 中的update语句回滚怎么写啊
我执行了一条update语句,可是错误了,结果把所有的数据都给改了,那么请问要怎么写回滚语句,我的sql语句大概是updatetablenamesetad=1111希望给...
我执行了一条update语句,可是错误了,结果把所有的数据都给改了,那么请问要怎么写回滚语句,我的sql语句大概是update tablename set ad=1111
希望给我写出准确的sql语句 展开
希望给我写出准确的sql语句 展开
6个回答
展开全部
回滚要放在事务里面进行,才能进行回滚;sql里面的事务使用关键字TransAction
1:可以用try catch捕获
begin try
begin tran
update table set a=1;
commit tran
end Try
begin catch
rollback tran
end catch
2:可以使用error 全局变量
begin tran
update tablename set ad=1111
if @@error<>0 begin rollback end
commit tran
注意:如果一个事务写了 begin trans ,后面一定要跟上 commit tran或 rollback transaction ,否则可能导致被锁
1:可以用try catch捕获
begin try
begin tran
update table set a=1;
commit tran
end Try
begin catch
rollback tran
end catch
2:可以使用error 全局变量
begin tran
update tablename set ad=1111
if @@error<>0 begin rollback end
commit tran
注意:如果一个事务写了 begin trans ,后面一定要跟上 commit tran或 rollback transaction ,否则可能导致被锁
展开全部
go
begin tran
update tablename set ad=1111
if @@error<>0 begin rollback end
commit tran
如果出错了 就会回滚,没出错就会提交
begin tran
update tablename set ad=1111
if @@error<>0 begin rollback end
commit tran
如果出错了 就会回滚,没出错就会提交
本回答被提问者采纳

你对这个回答的评价是?
展开全部
update tablename set ad=111 where .....有条件才行,不然全陪都改了
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
begin tran
update xdd set
a=1,
b=2,
where c=3 and c is not null
commit tran
update xdd set
a=1,
b=2,
where c=3 and c is not null
commit tran
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询