1

我有一个用于连接到 oracle db的.NET winforms应用程序。ODPODP 安装是 32 位的,我正在开发应用程序Win 7 64 bit machine。我在开发机器上将平台目标设置为 x86,它运行正常。但是当我在Win Server 2003 64 bit machine它上面测试应用程序时出现了异常

The type initializer for 'Oracle.DataAccess.Client.OracleCommand' threw an exception.                                            

UNHANDLED EXCEPTION STACK TRACE:at Oracle.DataAccess.Client.OracleCommand.Dispose(Boolean disposing) 
at System.ComponentModel.Component.Finalize()

UNHANDLED EXCEPTION SOURCE: Oracle.DataAccess

UNHANDLED EXCEPTION INNER EXCEPTION: Oracle.DataAccess.Client.OracleException The provider is not compatible with the version of Oracle client    at Oracle.DataAccess.Client.OracleInit.Initialize()
at Oracle.DataAccess.Client.OracleCommand..cctor()

UNHANDLED EXCEPTION DATA: System.Collections.ListDictionaryInternal

UNHANDLED EXCEPTION MESSAGE: The type initializer for 'Oracle.DataAccess.Client.OracleCommand' threw an exception.

当我将平台目标设置为Any CPUWindows 7 64 位时,它给出了异常:

Could not load file or assembly 'Oracle.DataAccess, Version=2.112.1.0, Culture=neutral, PublicKeyToken=89b483f429c47342' or one of its dependencies. An attempt was made to load a program with an incorrect format.

开发机(Win 7 64位)11.2.0上的ODP版本是,测试机上(Win Server 2003 64位)也是11.2.0

我应该怎么做才能在两台机器上运行应用程序?任何想法?

4

1 回答 1

0

IMO 有几个选项:

  1. 为 x86 编译并在您的 64 位服务器上安装 32 位 Oracle 客户端(如果您更改 ORACLE_HOME、TNS_ADMIN 等系统变量,可以并行运行);
  2. 为 x86 编译并将 32 位Oracle Instant Client的所有 DLL与您的二进制文件一起打包(确保设置了 TNS_ADMIN 系统变量,否则您将无法使用 LDAP 或 tnsnames);
  3. 为任何 CPU 编译您的应用程序,但为 x64 和 x86 位创建一组不同的 dll(Oracle.DataAcess.dll 是为特定架构编译的,有一个用于 x64 的版本和一个用于 x86 的版本);
  4. Oracle 正在开发托管 Oracle 驱动程序,不再需要 Oracle 客户端,大多数代码库都可以轻松转换,但请注意它的功能还不完整,仅支持 Oracle 11+ 数据库。
于 2013-06-25T12:28:50.487 回答