我已经阅读了 MSDN 关于ROLLBACK TRANSACTION和嵌套事务。虽然我看到了点ROLLBACK TRANSACTION savepointname
,但我不明白ROLLBACK TRANSACTION transactionname
。
- 它仅
transactionname
在最外层事务时才有效 ROLLBACK
总是回滚整个事务“堆栈”,除非是savepointname
基本上,当我阅读文档时,除了保存点之外,ROLLBACK
都会回滚所有事务(到@@TRANCOUNT=0
)。我能看到的唯一区别是这个片段:
如果在一组嵌套事务的任何级别执行使用外部事务名称的 ROLLBACK TRANSACTION transaction_name 语句,则所有嵌套事务都将回滚。如果在一组嵌套事务的任何级别执行不带 transaction_name 参数的 ROLLBACK WORK 或 ROLLBACK TRANSACTION 语句,它将回滚所有嵌套事务,包括最外层事务。
从阅读中,这向我表明回滚命名事务(必须是最外层事务的名称),只有嵌套事务将被回滚。这将为回滚命名事务提供一些意义。所以我设置了一个测试:
CREATE TABLE #TEMP (id varchar(50))
INSERT INTO #TEMP (id) VALUES ('NO')
SELECT id AS NOTRAN FROM #TEMP
SELECT @@TRANCOUNT AS NOTRAN_TRANCOUNT
BEGIN TRAN OUTERTRAN
INSERT INTO #TEMP (id) VALUES ('OUTER')
SELECT id AS OUTERTRAN FROM #TEMP
SELECT @@TRANCOUNT AS OUTERTRAN_TRANCOUNT
BEGIN TRAN INNERTRAN
INSERT INTO #TEMP (id) VALUES ('INNER')
SELECT id AS INNERTRAN FROM #TEMP
SELECT @@TRANCOUNT AS INNERTRAN_TRANCOUNT
ROLLBACK TRAN OUTERTRAN
IF @@TRANCOUNT > 0 ROLLBACK TRAN
SELECT id AS AFTERROLLBACK FROM #TEMP
SELECT @@TRANCOUNT AS AFTERROLLBACK_TRANCOUNT
DROP TABLE #TEMP
导致(所有“受影响的 X 行”内容被删除)
NOTRAN
--------------------------------------------------
NO
NOTRAN_TRANCOUNT
----------------
0
OUTERTRAN
--------------------------------------------------
NO
OUTER
OUTERTRAN_TRANCOUNT
-------------------
1
INNERTRAN
--------------------------------------------------
NO
OUTER
INNER
INNERTRAN_TRANCOUNT
-------------------
2
AFTERROLLBACK
--------------------------------------------------
NO
AFTERROLLBACK_TRANCOUNT
-----------------------
0
请注意,当我更改时,输出没有区别
ROLLBACK TRAN OUTERTRAN
简单地
ROLLBACK TRAN
那么有什么意义呢?ROLLBACK TRANSACTION named_transaction