SQL - 16.事务

指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)--也就是由多个sql语句组成,必须作为一个整体执行
这些sql语句作为一个整体一起向系统提交,要么都执行、要么都不执行
语法步骤:
开始事务:BEGIN TRANSACTION
事务提交:COMMIT TRANSACTION
事务回滚:ROLLBACK TRANSACTION
判断某条语句执行是否出错:
全局变量@@ERROR;
@@ERROR只能判断当前一条T-SQL语句执行是否有错,为了判断事务中所有T-SQL语句是否有错,我们需要对错误进行累计;
         例:SET @errorSum=@errorSum+@@error

 

如,借钱问题:
    假定钱从A转到B,至少需要两步:

  • A的资金减少
  • 然后B的资金相应增加   
隐藏行号 复制代码 这是一段程序代码。
 
UPDATE bank SET uMoney = uMoney - 1000
WHERE uName= '家宝'
@@error
UPDATE bank SET uMoney = uMoney + 1000
WHERE uName= '奥巴马'
@@error
--查看结果。
SELECT * FROM bank

 

CREATE TABLE bank
(
uName CHAR(10),  --姓名
uMoney MONEY     --当前余额
)
GO
ALTER TABLE bank
ADD CONSTRAINT CK_nowMoney    
CHECK(uMoney>=1)
GO
INSERT INTO bank(uName, uMoney)
VALUES('家宝',1000)
INSERT INTO bank(uName, uMoney)
VALUES('奥巴马',1)


例题:#

1.表category

select * from category

image

 

2.建立约束c_name名字不小于2个字

image

 

3.执行下列语句报错

update category set c_name = '1' where c_id =1

image

 

4.写事务

declare @errNum int
set @errNum=0
begin transaction      --先开始事务
update category set c_name = '1' where c_id =1
set @errNum =@errNum +@@error
delete from Category where c_id =120
set @errNum =@errNum +@@error
if @errNum=0
begin
    commit transaction
    print 'OK!'
end
else
begin
    rollback transaction
    print 'ERROR!'
end
select * from category

 

 

执行结果:

image

结果:c_id=120也没有删除

image

作者:【唐】三三

出处:https://www.cnblogs.com/tangge/archive/2012/08/24/2654332.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   【唐】三三  阅读(207)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu
点击右上角即可分享
微信分享提示