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

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

运行环境: IIS 7html

编程语言:C#数据库

数据库: 32位的Oracle 10g编程

运行缘由:64位操做系统C#客户端程序经过WCF访问ORACLE数据库服务器

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

 

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

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

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

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

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

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

 

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

相关文章
相关标签/搜索