【SQL】事务回滚

事务(Transaction)是并发控制的单位,是用户定义的一个操作序列。这些操作要么都做,要么都不做,是一个不可分割的工作单位。通过事务,SQL Server能将逻辑相关的一组操作绑定在一起,以便服务器保持数据的完整性

1.创建表

Create table tUser
(
UserCode varchar(50),
UserName varchar(50),
UserDuty varchar(50),
UserTel varchar(100)
);

 

2.事务回滚方法一:(记录错误条数)

declare @ErrorSum int
SET @ErrorSum=0
begin transaction

insert into tUser(UserCode,UserName,UserDuty,UserTel)
values('10000','张三','软件工程师','18469878542')
set @ErrorSum=@ErrorSum+@@ERROR
insert into tUser(UserCode,UserName,UserDuty,UserTel)
values('10001','王超群','软件工程师','13459687965')
set @ErrorSum=@ErrorSum+@@ERROR

if @ErrorSum=0
begin
COMMIT
end
else
begin
ROLLBACK
end

查询数据:
select * from tUser

 

3.事务回滚方法二:(捕获异常)

begin try
begin transaction


insert into tUser(UserCode,UserName,UserDuty,UserTel)
values('10002','李泽','测试工程师','15248963874')
insert into tUser(UserCode,UserName,UserDuty,UserTel)
values('10003','李志伟','项目工程师','13985478536')


COMMIT TRANSACTION
END TRY
BEGIN CATCH
ROLLBACK
END CATCH

查询数据:
select * from tUser

 

转载于:https://www.cnblogs.com/alwaysblog/p/5445233.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值