gpt4 book ai didi

sql - 首先提交;提交两个事务

转载 作者:行者123 更新时间:2023-12-04 18:28:43 25 4
gpt4 key购买 nike

请看下面的代码:

SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
alter PROCEDURE TestProc
AS
BEGIN
begin try

SET NOCOUNT ON;
--SET XACT_ABORT on;

set transaction isolation level read committed

create table #Test (id int)

begin transaction
insert into #Test values (1)
begin transaction
insert into #Test values (2)
commit
select * from #test
commit
select * from #test
end try

begin catch
print 'got here 1'
end catch
END
GO

由此调用:

begin try
exec TestProc
end try

begin catch
print @@TRANCOUNT
end catch

输出是:

table 1:
1
2

table 2:
1
2

为什么第一次提交;提交两个交易?请查看此链接:http://www.codeproject.com/Articles/4451/SQL-Server-Transactions-and-Error-Handling ,它说:“无论你将一组事务嵌套多深,只有最后一个 COMMIT 有任何效果。”。我希望第一个表只包含一行:

table 1
1

最佳答案

SQL Server 将像这样解析:

begin transaction 
insert into #Test values (1)
begin transaction
insert into #Test values (2)
commit
select * from #test
commit
select * from #test

第一个 select * 在第一个事务中。这意味着它可以完全访问之前在该事务中执行的内容。在同一事务中稍后执行的语句可以访问未提交的数据,就好像它已经提交一样。

关于sql - 首先提交;提交两个事务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36090658/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com