运行平台:Windows Server 2008 R2
运行环境: IIS 7
编程语言/程序: C# Web 应用程序
运行原因: 用MSDAORA.1驱动连接到Oracle
数据库
.
结果: 出现异常, 提示: The MSDAORA.1 provider is not registered on the local machine
程序在本地没问题, 布署到远程服务器上后,死活连不上
Oracle
数据库
, 一开始以为是”
MSDAORA
“驱动没装上,通过检查,
MSDAORA
其实已经存在. 然后怀疑
Oracle
Client 客户端没有装上,于是
Oracle
Client
也被装上了,但还是不行. 接下来就是各种怀疑,各种尝试,但都还是不行! 于是问道Google,见有一些老外说,
MSDAORA没有64bit的驱动,只有两种解决方案:
1.要么换驱动,换连接方式,比如可以改用Oracle提供的64位的驱动, 这意味着要改代码,可能要改很多,也可能不用改多少东西, 这主要看你自己的项目情况而定.
2.要么把程序全部(
包括所有的DLL
)重新编译,
编译
的目标是x86(32位), 然后再发布到远程服务器上.
经过短暂的怀疑后,还是决定相信老外, 决定试一下老外的方案, 我们当然选择简单的第2方案, 重新
编译
成x86再发布. 测试结果, 竟然行了, 唉,果然, 老外诚不欺我.
另外:实际操作过程中,还要记住
同时在IIS上, 在对应的应用程序池中,找到 “启用32位应用程序”选项, 将其设置为”true” ,就OK了.