码迷,mamicode.com
首页 > 数据库 > 详细

运行于64操作系统上的C#客户端通过WCF访问Oracle数据库不兼容问题

时间:2015-09-04 22:34:53      阅读:268      评论:0      收藏:0      [点我收藏+]

标签:

运行平台: Windows 7  64位操作系统

运行环境: IIS 7

编程语言:C#

数据库: 32位的Oracle 10g

运行原因:64位操作系统C#客户端程序通过WCF访问ORACLE数据库

结果产生异常:System.InvalidOperationException: 未在本地计算机上注册“MSDAORA”提供程序

 

      客户端程序在本地运行能够正常访问Oracle数据库数据, 但通过WCF连接不上Oracle数据库, 一开始以为是"MSDAORA"驱动没装上,通过检查,MSDAORA其实已经存在, Oracle Client 也已经装上,但还是不行。通过百度搜索发现MSDAORA没有用64bit的驱动,于是按照网上给出的解决方案进行尝试:

  方案:把程序全部(包括所有的DLL)重新编译,编译的目标是x86(32位), 然后再发布到远程服务器上。

  按照网上给出的方案对所以项目将编译目标改成x86后重新编译,运行客户端程序的时候却又出现了新的问题:

技术分享

   难道网上给出的方案不行吗?第一次遇到这种问题,百思不得其解,只能又求助于百度。经过又一轮的百度,发现将项目编译目标改成x86后重新编译还不够,还需要

配置一下IIS的应用程序池,将应用程序池配置成“启用32位应用程序”,如下图所示配置:

技术分享

经过更改IIS应用程序池配置后,再运行客户端程序,OK一切正常。

 

备注:因为客户端程序用C#编写所以标题中有C#关键字,但是其它编程语言编写的客户端程序可能也会遇到同样的问题。

运行于64操作系统上的C#客户端通过WCF访问Oracle数据库不兼容问题

标签:

原文地址:http://www.cnblogs.com/aishangfangbin/p/4782453.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!