更换服务器后,导致的事务问题

byj2001329 2006-09-01 08:34:14
因为系统的原因进行硬件升级

更新方法:
1、停掉Sql服务,从原服务器(和其它未更换的服务器存在发布订阅关系)拷贝所有的数据库文件到新服务器(除了tmpdb),路径等都保持原样。
2、修改服务器Ip,机器名和原来的一致。

问题:
启用新机器后,基本运行正常,但如果某个存储过程访问了某链接服务器,并设置了相关的事务,则提示不能执行分布事务(msdtc已经启动)。
...全文
134 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
byj2001329 2006-09-01
  • 打赏
  • 举报
回复
还有一点不同,就是原服务器装的win2000,新服务器是win2003sp2
不知是否有影响
byj2001329 2006-09-01
  • 打赏
  • 举报
回复
会不会是sql补丁不一致的原因
byj2001329 2006-09-01
  • 打赏
  • 举报
回复
这些存储过程原来都可以正常运行,复制了所有的系统表,应该设置是一样的吧?
leongwong 2006-09-01
  • 打赏
  • 举报
回复
SET XACT_ABORT
指定当 Transact-SQL 语句产生运行时错误时,Microsoft® SQL Server™ 是否自动回滚当前事务。
语法
SET XACT_ABORT { ON | OFF }
注释
当 SET XACT_ABORT 为 ON 时,如果 Transact-SQL 语句产生运行时错误,整个事务将终止并回滚。为 OFF 时,只回滚产生错误的 Transact-SQL 语句,而事务将继续进行处理。编译错误(如语法错误)不受 SET XACT_ABORT 的影响。

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

SET XACT_ABORT 的设置是在执行或运行时设置,而不是在分析时设置
leongwong 2006-09-01
  • 打赏
  • 举报
回复
哦,关注!
没有遇到过!
chyliu 2006-09-01
  • 打赏
  • 举报
回复
設置這個參數試試set xact_abort 我們以前的不可以,現在也可以了

22,207

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧