在分布式事务(MSDTC)中使用OLE DB数据库连接访问数据

简介:

在MSDTC中访问OLE DB数据库的时候,会抛出异常,异常信息大概是:"Microsoft.Jet.OLEDB.4.0”提供程序不支持 ITransactionLocal 接口。本地事务不可用于当前提供程序,或者是与基础事务通信失败。

原来,在创建OLE DB数据库连接的时候,默认是打开了事务的(automatic transaction enlistment),所以如果放在MSDTC中会出现上面的错误。

解决的办法是关闭OLEDB的自动事务处理,方法是在连接字符串中加入:

OLE DB Services = -4;

这样一来,不仅仅关闭了事务,还关闭了连接池,如果频繁的操作将会消耗部分性能,还是要慎重使用!

详细的可用服务列表如下:

image

MSDN中关于OLE DB Services的详细介绍:http://msdn.microsoft.com/en-us/library/ms717922(v=vs.85).aspx

 

image




本文转自齐师傅博客园博客,原文链接:http://www.cnblogs.com/youring2/archive/2013/01/26/2877918.html,如需转载请自行联系原作者
相关文章
|
3月前
|
运维 关系型数据库 分布式数据库
技术选型思考:分库分表和分布式DB(TiDB/OceanBase) 的权衡与抉择
技术选型思考:分库分表和分布式DB(TiDB/OceanBase) 的权衡与抉择
|
消息中间件 存储 缓存
干货 | 分布式缓存与DB秒级一致设计实践(2)
干货 | 分布式缓存与DB秒级一致设计实践
|
存储 消息中间件 缓存
干货 | 分布式缓存与DB秒级一致设计实践(1)
干货 | 分布式缓存与DB秒级一致设计实践
107 0
|
存储 关系型数据库 MySQL
传统应用层逻辑分库DB迁移阿里云DRDS+RDS分布式数据库
随着互联网快速发展,我们的结构化关系数据库在高并发、海量数据的情况下面临单机扩展性问题,首先是单机数据库容量瓶颈,单机数据库在业务高速增长的情况下依赖硬件升级也会到达天花板,并且使用成本变得非常高,而且扩展性的复杂性也是比较高,传统数据库扩容往往意味着服务中断,很难做到业务无感知或者少感知。
11534 1
|
存储 安全 Windows
SqlServer & Windows 可更新订阅立即更新启用分布式事务协调器(MSDTC)
原文:SqlServer & Windows 可更新订阅立即更新启用分布式事务协调器(MSDTC) 在可更新订阅中,在订阅设置更新方法,将 “排队更新” 设置为 “立即更新” 接着在订阅数据库更新表数据,出错: 消息 21079,级别 16,状态 1,过程 sp_getpublisherlink,第 52 行 没有发布服务器的 RPC 安全信息,或该信息无效。
1647 0
下一篇
DDNS