运行平台: 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#关键字,可是其它编程语言编写的客户端程序可能也会遇到一样的问题。