我终于承认失败并寻求帮助。我已经尽我所能来解决这个问题,但似乎我无能为力。
我正在使用:VS2010 C# Oracle 12c ODP.Net Managed121012
我继承了一个同时使用托管和非托管数据访问 dll 的应用程序。在我卸载 oracle 之前它一直在工作。然后我为 64 位机器重新安装了 11g 客户端。我马上注意到只安装了框架 2 的数据访问 dll,但我还是继续。然后,我将 client_1 文件夹中的所有 oci 和 ora dll 复制到我的应用程序的 bin 目录中,并将 Oracle.DataAccess.dll 也复制到我的 bin 目录中。我还将 Oracle.ManagedDataAccess.dll 复制到此文件夹中。
只要我没有更改数据集上的任何内容,我的应用程序就会成功运行。我会很乐意继续这样做,除非我必须创建更多数据集。当我尝试添加新数据集时,我的数据源连接向导下拉列表为空白。然后我尝试重新创建连接,但只能看到 .Net Framework DProviders。我看不到托管提供商。在某些时候,我也收到此错误“当前未选择数据提供者”。
认为这是因为未安装托管提供程序我卸载了 11g 客户端并安装了 64 位 12c 客户端并将所有相关文件复制到我的应用程序的 bin 中。我将以下行添加到我的 app.config 文件中:
<configSections>
<section name="oracle.manageddataaccess.client" type="OracleInternal.Common.ODPMSectionHandler, Oracle.ManagedDataAccess" />
<system.data>
<DbProviderFactories>
<remove invariant="Oracle.DataAccess.Client" />
<remove invariant="Oracle.ManagedDataAccess.Client" />
<add name="ODP.NET, Managed Driver" invariant="Oracle.DataAccess.Client"
description="Oracle Data Provider for .NET, Managed Driver"
type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.121.1.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
</DbProviderFactories>
在此之后,我现在可以看到一些旧数据源,但我无法连接到我的数据库,因为我收到“连接请求超时”。当我手动创建新连接时,我可以与非托管提供程序正常连接,但会收到连接请求超时错误。
我真的在我的绳索尽头,在我使用绳索之前真的很感激新鲜的眼睛。
提前致谢。