数据库学习笔记(5)——事务

一,概念

事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,
–如果任何一个语句操作失败那么整个操作就被失败,
–进而回滚到操作前状态,或者是上个节点。
–为了确保要么执行,要么不执行,就可以使用事务。

事务的四大特性(ACID)

要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。

二,事务的创建及使用

我们先在数据库创建一张Customers表并给它添加数据
在这里插入图片描述

在这里插入图片描述
1,开启事务
2,提交事务
3,如果前面有错,则回滚事务

go
--定义一个变量,记录错误数
declare @error_nums int
set @error_nums=0

begin transaction tran_change  --开始事务
begin try
update Customers set Remain=Remain-300 where id=2
set @error_nums=@error_nums+@@error
update Customers set Remain=Remain+300 where id=1
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 --执行事务

一个完整的事务就创建好了,接下来让我们来试一试它的效果吧
执行事务,并查询表格

select * from Customers

我们要的效果是,李四向张三转账300
我们可以看到,张三的余额增加了300,而李四的余额减少了300,证明事务执行成功

在这里插入图片描述一个简单的事务就创建好了,你也一起来试一试吧~

猜你喜欢

转载自blog.csdn.net/AKahong/article/details/106465873