[英]Oracle ODP.NET Managed Driver running 50-100% slower in 64bit than in 32bit
[英]ODP.NET for both 32bit and 64bit
我正在开发使用ODP.NET连接到Oracle DB的应用程序。 我想为32位和64位机器提供一个版本。 问题是我无法弄清楚如何使用anycpu目标构建projetc,似乎它要求目标与ODP驱动程序版本相同。 因此,这意味着我需要同一个应用程序的版本,一个用于32位,另一个用于64位。 但使用MS .NET Oracle客户端(System.Data.OracleClient)时同样没问题。 有没有办法在MS .NET客户端上使用ODP.NET具有相同的行为?
几年后更新:Oracle发布了托管的ODP.NET客户端,因此不再需要在.NET应用程序中使用x64 / x86。 您可以在Oracle网站上找到更多信息: http : //www.oracle.com/technetwork/topics/dotnet/index-085163.html
根本原因是ODP.NET依赖于本机 OCI DLL ,当然这不是“任何CPU”。
从理论上讲,ODP.NET可以检测.NET代码中当前执行的“bit-ness”,然后相应地动态加载32位或64位本机DLL,但这不是当前实现的方式。
任何C#项目的默认选项是它可以在x64和x86操作系统上运行。
因此,这意味着我需要同一个应用程序的版本,一个用于32位,另一个用于64位。 但使用MS .NET Oracle客户端(System.Data.OracleClient)时同样没问题。
这是预期的....你需要发布一个x86版本和一个x64版本,请注意,x86应用程序不能引用x64程序集,反之亦然。
Microsoft引用不同的原因是默认情况下它是.NET Framework的一部分。
我无法下载我所在的文件,我相信,ODP.NET有一个x86程序集和一个x64程序集。
正确的方法是发布程序的x86版本和x64版本。
ODP.NET专为32位或64位平台而构建。 他们可以为AnyCPU构建一个单独的库,允许它在32位或64位进程中使用。 然而,正如Branko Dimitrijevic所提到的,ODP.NET托管的dll在幕后使用本机库。 本机库是特定于平台的; 因此要求Oracle为每个平台构建单独的ODP.NET库。 没有替代。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.