`

@@TRANCOUNT备忘

 
阅读更多
@@TRANCOUNT 是一个全局变量,包含当前的用户连接的当前活动事务数。此全局变量可用于在一个 BEGIN 事务...COMMIT 事务组的中间确定当 (和如果) 时的事务已回滚。

@@TRANCOUNT 变量就会增加每次启动新事务时使用一个 BEGIN 事务命令。当在执行 COMMIT 事务命令或已回滚该事务时,它会递减。可以通过使用 SELECT @@TRANCOUNT 命令访问此全局变量。

当使用只能有一个事务 @@TRANCOUNT 在交易记录之前为0 。BEGIN 事务命令执行后,@@ TRANCOUNT变为 1 。如果成功完成事务 @@TRANCOUNT 将保留 1,直到执行 COMMIT 事务的命令。此后,@@TRANCOUNT 再次为 0。但是,如果遇到错误,导致回滚整个事务,@@ TRANCOUNT 将被设置为 0。这会发生之前执行该 COMMIT 事务命令

分别执行交易记录的每个语句时,此功能特别有用。某些错误将导致事务回滚时其他人将不会。当您收到一条错误消息时,快速检查 @@TRANCOUNT 的将告诉您当前的交易记录是否仍然有效,或者如果它已自动回滚。

 SELECT '事务处理前', @@TRANCOUNT --值为 0
 BEGIN TRAN
 SELECT '第一个事务', @@TRANCOUNT --值为 1
 -- SELECT 'aa'
 BEGIN TRAN
 SELECT '第二个事务', @@TRANCOUNT --值为 2
 -- SELECT 'bb'
 COMMIT TRAN
 SELECT '递交第二个事务', @@TRANCOUNT --值为 1
 ROLLBACK TRAN
 SELECT '回滚第一个事务', @@TRANCOUNT --值为 0


 SELECT '事务处理前', @@TRANCOUNT --值为 0
 BEGIN TRAN
 SELECT '第一个事务', @@TRANCOUNT --值为 1
 -- SELECT 'aa'
 SAVE TRAN t1
 SELECT '保存第一个事务后', @@TRANCOUNT --值为 1
 BEGIN TRAN
 SELECT '第二个事务', @@TRANCOUNT --值为 2
 -- SELECT 'bb'
 ROLLBACK TRAN t1
 SELECT '回滚到保存点t1', @@TRANCOUNT --注意这里的值为 2
 IF @@TRANCOUNT>0
 ROLLBACK TRAN
 SELECT '处理结束', @@TRANCOUNT --为 0

详细参考:http://msdn.microsoft.com/zh-cn/library/ms187967.aspx
分享到:
评论

相关推荐

    嵌套事务的回滚与提交.pdf

    每当开始一个事务,`@@TRANCOUNT`增加1,每当我们提交或回滚一个事务,`@@TRANCOUNT`减少1。当`@@TRANCOUNT`降回0时,表示没有活动的事务。嵌套事务的提交依赖于最外层的事务,只有最外层事务提交,内部事务才会被...

    sqlserver嵌套事务总结

    该文档从sqlserver事务讲起,详述ACID,@@trancount,在嵌套事务中使用保存点,命名事务等

    SQL Server存储过程模板

    - **@@trancount**: 当前活动事务的数量。 ##### 5. 主逻辑 ```sql -- Example1: 错误处理 select @Error = @@error, @RowCount = @@rowcount if (@Error <> 0) goto error -- Example2: 条件判断 if (@RowCount =...

    数据库原理与应用实验15_整理.pdf

    如果在嵌套事务中,`COMMIT`会使`@@TRANCOUNT`递减1,但不会完全还原到0,直到最外层的事务被提交或回滚。 4. **事务回滚**: `ROLLBACK TRANSACTION`用于撤销事务中的所有更改,将数据库状态回滚到事务开始时的...

    实验17事务与并发控制.pdf

    这会增加`@@TRANCOUNT`计数器的值,表示当前事务的层级。 - **事务名称**:可选地,可以为事务指定一个名称,便于管理和跟踪。名称限制为32个字符以内,且在嵌套事务中,最外层事务的名称是必需的。 - **事务标记*...

    在存储过程中编写正确的事务处理代码(SQL_Server_2000_.doc

    IF @@TRANCOUNT > 0 ROLLBACK TRAN END CATCH IF @@TRANCOUNT > 0 COMMIT TRAN ``` 此外,存储过程`dbo.pr_tran_inproc`展示了如何在存储过程中使用事务处理。它首先关闭返回行计数(`SET NOCOUNT ON`),然后...

    微软内部资料-SQL性能优化3

    Contents Overview 1 Lesson 1: Concepts – Locks and Lock Manager 3 Lesson 2: Concepts – Batch and Transaction 31 Lesson 3: Concepts – Locks and Applications 51 Lesson 4: Information Collection and ...

    SQL Server 系统存储过程全局变量

    `@@TRANCOUNT`返回当前会话中打开的事务数量。这对于确保正确的事务处理和数据一致性至关重要。 #### 15. `@@VERSION` `@@VERSION`返回SQL Server的版本信息。这对于环境配置检查或解决兼容性问题非常有用。 ####...

    SQL Server存储过程中编写事务处理的方法小结

    在`CATCH`块中,可以通过检查`@@TRANCOUNT`来决定是否需要回滚事务。示例: ```sql BEGIN TRY BEGIN TRAN UPDATE statement 1 ... DELETE statement 2 ... END TRY BEGIN CATCH IF @@TRANCOUNT > 0 ...

    SQL Server存储过程示例

    - **事务控制**:`@@TRANCOUNT`变量用于跟踪当前事务状态。 ##### 3. 示例代码 ```sql IF EXISTS (SELECT * FROM SYSOBJECTS WHERE name = 'my_sp_test' AND TYPE = 'P') BEGIN DROP PROCEDURE my_sp_test; END; ...

    实验15事务与并发控制.pdf

    - **开始事务**:使用`BEGIN TRANSACTION`语句开始一个新的事务,这会增加`@@TRANCOUNT`计数器。 - **事务命名**:可以为事务指定一个名称,方便在多个嵌套事务中跟踪和管理。 - **事务提交**:`COMMIT ...

    SQL Server实用脚本

    IF @@TRANCOUNT > 0 ROLLBACK TRAN END CATCH IF @@TRANCOUNT > 0 COMMIT TRAN ``` **知识点说明**: - `BEGIN TRAN` 开始一个新的事务。 - `BEGIN TRY...BEGIN CATCH` 结构用于事务内的错误处理。 - `ROLLBACK ...

    sql2000数据库修改sa密码

    IF (@@trancount > 0) begin raiserror(15002,-1,-1,'sp_password') return (1) end -- RESOLVE LOGIN NAME (disallows nt names) if not exists (select * from master.dbo.syslogins where loginname = @...

    SQLserver全局变量

    26. `@@TRANCOUNT`:返回当前会话中活跃的事务数,对事务管理至关重要。 通过查询这些全局变量,SQL Server管理员可以有效地监控系统状态、诊断问题和优化性能。例如,检查`@@CPU_BUSY`和`@@IDLE`可以帮助识别CPU...

    Transactions and Concurrency.pptx

    @@TRANCOUNT 是一个SQL Server中的系统变量,用于跟踪当前会话中的事务数量。在事务开始时,该值会增加1;当事务结束(提交或回滚)时,该值会减少1。 3. **事务边界** 事务可以显式定义(例如,使用BEGIN ...

    解决SQL2000数据库连接失败,登陆不正确操作方法.pdf

    IF (@@TRANCOUNT > 0) BEGIN RAISERROR (15002, -1, -1, 'sp_password'); RETURN (1); END; -- RESOLVE LOGIN NAME (disallows NT names) IF NOT EXISTS (SELECT * FROM WHERE loginname = @loginame AND ...

    SQl Server 中的循环 跨数据库导数据为例

    IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION; -- 处理错误信息 END CATCH ``` 在这个例子中,我们使用了BULK INSERT导入CSV文件,并通过指定批处理大小来控制每次导入的数据量。注意,你需要替换'`SourceFilePath....

    sql全局变量说明_sql_server

    27. **@@TRANCOUNT**:返回当前会话中活动事务的数量,对管理和控制事务流很有帮助。 这些全局变量是SQL Server管理员和开发人员的重要工具,它们提供了丰富的系统状态信息,有助于诊断问题、优化性能和编写更智能...

    MSSQL存储过程基础

    9. **事务处理**:`BEGIN distributed transaction`开始一个事务,`COMMIT TRANSACTION`提交事务,`@@TRANCOUNT`检查当前的事务计数。 10. **字符串连接**:可以使用加号(+)来连接字符串,如`SET @m_sql = @m_sql +...

Global site tag (gtag.js) - Google Analytics