事务要求语句全部执行成功或者全部不执行。作为一个整体进行操作。
因此适用于一些特殊场景
事务分为显式事务和隐式事务
隐式事务:不用刻意强调,本身就是事务的语句,如单独的sql语句;
语法:
--创建事务:
begin transaction
begin
sql语句1
sql语句2
sql语句3
...
if(@@ERROR<>0) --判断语句是否出现错误
begin
rollback --出现错误则各个表回滚到自己的原始状态
end
else
begin
commit transaction --未出现错误则提交保存
end
end
--------------------------------------------------------------------例:
begin transaction --事务开始
commit transaction --事务提交
rollback transaction--事务回滚
--事务:事务中的语句如果要执行都执行,如果有一个不执行所有语句都不执行
--一个操作里面有10条语句
--业务场景:A银行 B银行
--用户admin在两个行中分别开设了两个账号,admin从A银行进行金额转账 转到B银行
alter proc pr_zhuanzhang
@a_account varchar(50),
@zmoney int
as
declare @ymoney int
select @ymoney=money from abank where Account=@a_account--查出余额
if(@zmoney>@ymoney)
begin
print '余额不足'
end
else
begin
--创建事务
begin transaction
begin
--先从a银行减掉
update abank set money=money-@zmoney where Account=@a_account
--把减掉的钱加到B银行
update bbank set money=money+@zmoney where Account=@a_account
if(@@ERROR<>0)
begin
rollback --各个表回到自己的原始状态
end
else
begin
commit transaction --提交
end
end
end
go
exec pr_zhuanzhang 'admin',500
select * from abank
select * from bbank
SET IMPLICIT_TRANSACTIONS ON