日期:2014-05-19  浏览次数:20492 次

这个错误提示是什么意思?
Server:   Msg   7395,   Level   16,   State   2,   Procedure   tr_doucment_u,   Line   5
Unable   to   start   a   nested   transaction   for   OLE   DB   provider   'SQLOLEDB '.    
A   nested   transaction   was   required   because   the   XACT_ABORT   option   was   set   to   OFF.
[OLE/DB   provider   returned   message:   Cannot   start   more   transactions   on   this   session.]
---------------------------------
我更新一个表,这个表有个update触发器,触发器代码是一个update语句。更新时出现上面的出错提示。但是在更新之前set   xact_abort   on   就没问题了,为什么?

------解决方案--------------------
SET XACT_ABORT
指定当 Transact-SQL 语句产生运行时错误时,Microsoft® SQL Server™ 是否自动回滚当前事务。
当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。

对于大多数 OLE DB 提供程序(包括 SQL Server),隐性或显式事务中的数据修改语句必须将 XACT_ABORT 设置为 ON

------解决方案--------------------
使用了递归触发器?
------解决方案--------------------
SET XACT_ABORT ON
当一个事物开启后,其中出现错误,系统即默认回滚事务.
SET XACT_ABORT Off
当一个事物开启后,其中出现错误,系统只是回滚产生错误语句的事务,但能够提交其它正确的

看来有错是肯定的。。。。
------解决方案--------------------
好快哟。。。
------解决方案--------------------
就是默认的意思撒~~
------解决方案--------------------
看错了....上网找找~~~
------解决方案--------------------
把东西写简单点丢出来看看~~
------解决方案--------------------
http://topic.csdn.net/t/20030921/23/2285065.html
------解决方案--------------------
另外,触发器更新的是连接服务器中的一个表
----------------------------------------------------
那就对了嘛,你这是用到了分布式事务,你好好看看相关说明:


如果 SET XACT_ABORT 设置为 OFF,则链接服务器还必须支持嵌套事务,才能对其执行更新操作。
------解决方案--------------------
好像没有你要的答案哟。。。。再看看。。。。
------解决方案--------------------
GEPIN(极品)
可以用例子讲讲为什么吗???