终于认输求助了。我已经做了我能想到的一切来解决这个问题,但我似乎做不到。
我正在与: VS2010 C# 甲骨文 12c ODP.Net Managed121012
我继承了一个同时使用托管和非托管数据访问 dll 的应用程序。在我卸载 oracle 之前,它一直在工作。然后我为 64 位机器重新安装了 11g 客户端。我马上注意到只安装了 framework 2 的 dataaccess 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>
在此之后我现在可以看到一些旧的数据源,但是我无法连接到我的数据库,因为我收到“连接请求超时”。当我手动创建新连接时,我可以很好地与非托管提供程序连接,但出现连接请求超时错误。
我真的在我的绳索的尽头,在我使用绳索之前真的很感激新鲜的眼睛。
提前致谢。
切换到托管驱动程序后我遇到了同样的问题。甚至使用本机和托管驱动程序编写了一个测试应用程序。结论是托管驱动程序需要比本机驱动程序更多的时间来打开新连接。一个对我们有用的解决方案是使用连接字符串设置一个大的连接超时。
<connectionStrings>
<add name="ConnectionString" connectionString="data source=xxxx;user id=xxxx;password=xxxx;persist security info=false;Connection Timeout=120;" />
</connectionStrings>
以防万一有人在 mono 4.8 上运行时遇到这个问题。似乎有一个同步错误,导致 Oracle 客户端在使用所有连接后无法扩展连接池。看到这个bug
我们在 Visual Studio 中使用即时窗口进行一些测试时看到了同样的错误。我们真的很困惑,直到我们正常运行代码(不使用立即窗口)并且问题消失了。因此,与 Oracle ManagedDataAccess 和 Visual Studio 中的即时窗口有某种交互可能会导致此错误。
我知道这不会成为你们大多数人的答案,但我希望它对某人有用。
请检查Oracle输出参数。因为我的应用程序也面临同样的情况。
我们将 oracle output 参数更改为 Refcursor。也许这个解决方案是有用的。
返回 Oracle.ManagedDataAccess.Core.dll 版本 3.21.1
命名空间与使用 Oracle.ManagedDataAccess.Client 相同