SQL Server 事务

本文介绍了SQL Server中事务的基本概念,强调了事务的ACID特性,并通过一个银行转账的存储过程实例,展示了事务在确保数据一致性和完整性方面的关键作用。当转账过程中发生错误,事务能够自动回滚,保持数据的正确状态。

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

1.事务定义:

事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。

2.事务实例:

sql中的事物一般是配合存储过程来用的
所以这次使用存储过程+事务作为例子(此例子是模仿银行转账)
先上图,这是表结构👇
在这里插入图片描述
这是表数据👇
在这里插入图片描述



--定义一个变量,记录错误数

GO
CREATE PROC change--创建一个名为change的存储过程
(
@idOut int,--转账人ID
@idIn int,--收账人ID
@remain money--转账金额
)
as
DECLARE @error_nums int--此变量用来记录错误数

set @error_nums=0--初始化变量
begin transaction tran_change -- -开始事务
begin try --开始尝试
update customers set Remain=Remain -@remain where id=@idOut--转账人总金额=总金额-转账金额

set @error_nums=@error_nums+@@error
update customers set Remain=Remain+@remain where id=@idIn--收账人总金额=总金额+转账金额

set @error_nums=@error_nums+@@error

end try
begin catch--捕捉错误

set @error_nums=@error_nums+1
print '错误 异常:'+convert (varchar, error_number())+' ,错误消息'+error_message()--打印错误

end catch
if (@error_nums>0) --表示前面有错

rollback transaction tran_change-- 回滚事务

else

commit transaction tran_change
--执行事务.
------------------------我是分割线---------------------------
exEc change 2,1,500--执行存储过程,2为转账人id,1为收账人id,500为转账金额

正确的执行结果如下👇
在这里插入图片描述
错误的执行结果(总金额不能满足转账金额),👇

exEc change 2,1,1500--由上表可知,小张的总金额不能满足转账金额

在这里插入图片描述
此图可知,结果还是没变。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值