教程集 www.jiaochengji.com
教程集 >  数据库  >  mssql  >  正文 sqlserver事务处理的代码

sqlserver事务处理的代码

发布时间:2014-07-20   编辑:jiaochengji.com
sqlserver事务处理的代码,当对多个表进行更新的时候,某条执行失败。<br /> 为了保持数据的完整性,需要使用事务回滚...

当对多个表进行更新的时候,某条执行失败。
为了保持数据的完整性,需要使用事务回滚。

显示设置事务
复制代码 代码如下:


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
 


隐式设置事务
 

复制代码 代码如下:

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
 


显示事务以下语句不能使用,隐式事务可以
 

复制代码 代码如下:

alter database;
backup;
create database;
drop database;
reconfigure;
restore;
update statistics;
 


显示事务可以嵌套使用
复制代码 代码如下:


--创建存储过程
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

事务嵌套,回滚外层事务时,如果嵌套内的事务已经回滚过则会有异常。
此时便需要使用事务保存点,如上代码所示。

您可能感兴趣的文章:
sqlserver事务处理的代码
php源码怎么连mssql数据库
sysservers 中找不到服务器,请执行 sp_addlinkedserver 将该服务器添加到sysserver 的解决方法
认识ASP.NET会话状态
写asp.net论坛时用的一个技巧
查询sqlserver数据库大小的语句
将图片插入数据库并使用asp.net读取出来的正确方
golang 连接 sqlserver 数据库
ASP连接SQL Server数据库程序代码
Tomcat下配置SQLServer连接池的方法步骤

[关闭]
~ ~