sql server 数据库的事务笔记

本文主要探讨了SQL Server数据库中的事务概念,强调了事务作为逻辑工作单元的重要性,特别是在处理大量和复杂数据时确保数据库完整性的关键作用。内容涵盖事务的定义、使用场景,以及一个关于转账功能的扩展例子,包括存储过程的创建和MVC模式的应用。
摘要由CSDN通过智能技术生成

sql server 数据库的事务

一.定义
事务就是被绑定在一起作为一个逻辑工作单元的SQL语句组,如果任何一个语句操作失败那么整个操作就被失败,进而回滚到操作前状态,或者是上个节点。为了确保要么执行,要么不执行,就可以使用事务。要将一组语句作为事务考虑,就需要通过ACID测试,即原子性,一致性,隔离性和持久性。
二.什么情况用事务
当数据库需要处理操作量大、复杂度高的数据的时候需要用到事务。用事务是为了保证数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。
三.使用举例

--转账
go
--定义一个变量,记录错误数
declare @error_nums int set @error_nums=0
--开始事务
begin transaction tran_change
begin try
update Customer set Remain=Remain-200 where id=1
set @error_nums=@error_nums+@@ERROR
update Customer set Remain=Remain+200 where id=2
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 Customer

表构造
四.扩展(转账功能)
1.创建存储过程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值