根事务要确认,但事务中止了操作—解决办法

根事务要确认,但事务中止了操作—解决办法

 

SQL 报如上的错误:是因为 没有使用 SET XACT_ABORT ON

 

begin tran/***/commit tran 之前使用了 SET XACT_ABORT ON 才能回滚

 

 

----------------------------

当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。

对于大多数 OLE DB 提供程序(包括 SQL Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为 ON。唯一不需要该选项的情况是提供程序支持嵌套事务时。有关更多信息,请参见分布式查询和分布式事务。

SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置。

 

参考网址:http://blog.csdn.net/fengchao1000/article/details/7717841

 

posted @ 2016-05-10 23:16  微点安全  阅读(802)  评论(0编辑  收藏  举报