热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

TransactioncountafterEXECUTEindicatesamismatchingnumberofBEGINandCOMMITstatements

TransactioncountafterEXECUTEindicatesamismatchingnumberofBEGINandCOMMITstatements

Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements

开始想写一个过程,根据一个项目的数据库的一个表的导数据到另一个数据库中去,本来在本地测试时蛮好的,但是将过程升级到生产服务器之后运行之后,根据下面类似的错误信息发现是生产服务器上引用的数据库名不对。

Msg 208, Level 16, State 1, Procedure test_sp, Line 10
Invalid object name 'test.dbo.col1'.
Msg 266, Level 16, State 2, Procedure test_sp, Line 10
Transaction count after EXECUTE indicates a mismatching number of BEGIN and COMMIT statements. Previous count = 0, current count = 1

出现了这个错之后就去查了下需要插入的表,发现锁表了,所以猜测是不是刚刚运行的过程的事务没有回滚(或提交)。就关闭当前查询窗口,出现如下信息证实了猜测:
enter description here
但是过程中的TRY CATCH语句块中已经写有ROLLBACK了。此时,不得不怀疑是不是自己写的TRY CATCH有问题,首先在过程中添加SELECT 1/0,对于这一错误ROLLBACK是起作用的。后来就去MSDN看TRY CATCH帮助文档,发现有这么一段说明:
enter description here
这个完全符合我遇到的情况,所以原来就是引用表的数据库名写错,造成致命性错误,使得CATCH捕捉不到异常,所以事务没能ROLLBACK

演示

我就改写我的过程来演示遇到的问题和解决这个问题的方案。T1表中只有3条数据
enter description here

CREATE PROCEDURE [dbo].[test_sp] AS BEGIN TRY BEGIN TRAN SET NOCOUNT ON;         
        INSERT INTO T1( col1, col2 )VALUES( 3,3);

        SELECT * FROM T1;

        SELECT * FROM [AdventureWorks2012].[dbo].[T2] COMMIT TRAN;
END TRY BEGIN CATCH ROLLBACK TRAN;
    
    THROW;
END CATCH 

查询1窗口执行test_sp过程

EXEC test_sp

--连接上执行的 BEGIN TRANSACTION 语句的数目
SELECT @@TRANCOUNT AS Trancount 

 

enter description here

1460734370861.jpg

 

 

enter description here

1460736223442.jpg

如果想关闭当前 查询1窗口,弹出信息:

 

 

enter description here

1460734736433.jpg

 

查询2窗口查询T1[AdventureWorks2012].[dbo].[T2]

--查询T1
SELECT * FROM T1;

T1一直被查询1的事务占用:

 

enter description here

1460734465672.jpg

 

--查询T2
SELECT * FROM [AdventureWorks2012].[dbo].[T2] 

T2没有创建:

 

enter description here

1460734518647.jpg

 

解决方案

首先使用KILL命令将查询1的连接给断开,然后在test_sp中设置XACT_ABORTON。如果XACT_ABORTON时,如果执行 Transact-SQL 语句产生运行时错误,则整个事务将终止并回滚;为 OFF 时,有时只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。 如果错误很严重,那么即使 SET XACT_ABORT 为 OFF,也可能回滚整个事务。 OFF 是默认设置。

SET XACT_ABORT ON; 

我们在查询1窗口中重新运行,顺带尝试关闭窗口:

EXEC test_sp

SELECT @@TRANCOUNT AS Trancount --查询T1 SELECT * FROM T1;

 

enter description here

1460735835769.jpg

 

 

enter description here

1460736150990.jpg

 

 

enter description here

1460736007326.jpg

@@TRANCOUNT为0, T1表还是只有3条纪录,说明事务顺利的终止并且回滚了。

 

我们在AdventureWorks2012数据库中创建t2

CREATE TABLE t2 (col1 int) 

查询1中先运行一遍将第4条数据插入,再运行第二遍。

EXEC test_sp 

 

enter description here

1460736881949.jpg

由于主键约束,抛出异常,我们可以检查当前连接的事务连接数也是 0

 

SELECT @@TRANCOUNT AS Trancount 

 

enter description here

1460736950117.jpg

 

结论

设置XACT_ABORTON时,即使过程中没有TRY CATCH,如果语句导致任何异常才会发生回滚。所以我们要灵活使用XACT_ABORT,如果使用TRY CATCH能够捕捉所有需要解决的错误时,我们就不必开启XACT_ABORT,只有错误比较严重时才考虑XACT_ABORTON

所以,我应该滚回去修改引用的数据库名就好了。

参考:
http://www.cnblogs.com/chenxizhang/archive/2008/07/29/1255737.html
https://technet.microsoft.com/zh-cn/library/ms164086.aspx
https://msdn.microsoft.com/zh-cn/library/ms188792(v=sql.120).aspx
https://www.mssqltips.com/sqlservertip/4018/sql-server-transaction-count-after-execute-indicates-a-mismatching-number-of-begin-and-commit-statements/


返回顶部

推荐阅读
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文详细介绍了在ASP.NET中获取插入记录的ID的几种方法,包括使用SCOPE_IDENTITY()和IDENT_CURRENT()函数,以及通过ExecuteReader方法执行SQL语句获取ID的步骤。同时,还提供了使用这些方法的示例代码和注意事项。对于需要获取表中最后一个插入操作所产生的ID或马上使用刚插入的新记录ID的开发者来说,本文提供了一些有用的技巧和建议。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文详细介绍了MySQL表分区的创建、增加和删除方法,包括查看分区数据量和全库数据量的方法。欢迎大家阅读并给予点评。 ... [详细]
  • 本文介绍了一些Java开发项目管理工具及其配置教程,包括团队协同工具worktil,版本管理工具GitLab,自动化构建工具Jenkins,项目管理工具Maven和Maven私服Nexus,以及Mybatis的安装和代码自动生成工具。提供了相关链接供读者参考。 ... [详细]
  • 本文介绍了在Linux下安装和配置Kafka的方法,包括安装JDK、下载和解压Kafka、配置Kafka的参数,以及配置Kafka的日志目录、服务器IP和日志存放路径等。同时还提供了单机配置部署的方法和zookeeper地址和端口的配置。通过实操成功的案例,帮助读者快速完成Kafka的安装和配置。 ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • IT方面的论坛太多了,有综合,有专业,有行业,在各个论坛里混了几年,体会颇深,以前是论坛哪里人多 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • MySQL语句大全:创建、授权、查询、修改等【MySQL】的使用方法详解
    本文详细介绍了MySQL语句的使用方法,包括创建用户、授权、查询、修改等操作。通过连接MySQL数据库,可以使用命令创建用户,并指定该用户在哪个主机上可以登录。同时,还可以设置用户的登录密码。通过本文,您可以全面了解MySQL语句的使用方法。 ... [详细]
  • 本文介绍了Oracle存储过程的基本语法和写法示例,同时还介绍了已命名的系统异常的产生原因。 ... [详细]
author-avatar
mobiledu2502874483
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有