源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

SQL Server重温 事务

  • 时间:2020-12-04 04:11 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:SQL Server重温 事务
为什么使用事务   当对多个表进行更新的时候,某条执行失败。为了保持数据的完整性,需要使用事务回滚。 显示设置事务
[u]复制代码[/u] 代码如下:
begin try begin transaction insert into shiwu (asd) values ('aasdasda'); commit transaction end try begin catch select ERROR_NUMBER() as errornumber rollback transaction end catch
隐式设置事务
[u]复制代码[/u] 代码如下:
set implicit_transactions on; -- 启动隐式事务 go begin try insert into shiwu (asd) values ('aasdasda'); insert into shiwu (asd) values ('aasdasda'); commit transaction; end try begin catch select ERROR_NUMBER() as errornumber rollback transaction; --回滚事务 end catch set implicit_transactions off; --关闭隐式事务 go
显示事务以下语句不能使用,隐式事务可以
[u]复制代码[/u] 代码如下:
alter database; backup; create database; drop database; reconfigure; restore; update statistics;
显示事务可以嵌套使用
[u]复制代码[/u] 代码如下:
--创建存储过程 create procedure qiantaoProc @asd nchar(10) as begin begin try begin transaction innerTrans save transaction savepoint --创建事务保存点 insert into shiwu (asd) values (@asd); commit transaction innerTrans end try begin catch rollback transaction savepoint --回滚到保存点 commit transaction innerTrans end catch end go begin transaction outrans exec qiantaoProc 'asdasd'; rollback transaction outrans
事务嵌套,回滚外层事务时,如果嵌套内的事务已经回滚过则会有异常。此时需要使用事务保存点。如上代码。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部