SQL Server重温 事务
程序员文章站
2023-12-01 09:43:10
为什么使用事务 当对多个表进行更新的时候,某条执行失败。为了保持数据的完整性,需要使用事务回滚。 显示设置事务 复制代码 代码如下: begin try begin t...
为什么使用事务
当对多个表进行更新的时候,某条执行失败。为了保持数据的完整性,需要使用事务回滚。
显示设置事务
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
事务嵌套,回滚外层事务时,如果嵌套内的事务已经回滚过则会有异常。此时需要使用事务保存点。如上代码。
当对多个表进行更新的时候,某条执行失败。为了保持数据的完整性,需要使用事务回滚。
显示设置事务
复制代码 代码如下:
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
事务嵌套,回滚外层事务时,如果嵌套内的事务已经回滚过则会有异常。此时需要使用事务保存点。如上代码。
推荐阅读
-
sql-server索引
-
无法找到产品Microsoft SQL Server Native Client的安装程序包的解决方法Sqlncli.msi
-
Sql Server 2012的扩展事件详细使用图文教程
-
sql server2005进程无法向表"dbo"."xxx"进行大容量复制(错误号: MSSQL_REPL20037)
-
SQL Server 2008 连接JDBC详细图文教程
-
sql server 2005如何导出数据到oracle 11g
-
SQL Server数据库损坏检测以及SQL Server数据库修复的解决方法
-
SQL Server DBA日常检查常用SQL
-
SQL Server页类型汇总+疑问汇总
-
oracle 合并查询 事务 sql函数小知识学习