我尝试在我的应用程序中使用 Oracle.ManagedDataAccess.Client。我将此添加到我的 app.config(嵌入式资源)中:
<system.data>
<DbProviderFactories>
<remove invariant="Oracle.ManagedDataAccess.Client"/>
<add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver" type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342"/>
</DbProviderFactories>
</system.data>
DBFactories 列表不包含 Oracle.ManagedDataAccess.Client。当我将相同的条目添加到我的 maschine.config (C:\Windows\Microsoft.NET\Framework\v4.0.30319\Config) 时,一切正常。
<add name="ODP.NET, Managed Driver" invariant="Oracle.ManagedDataAccess.Client" description="Oracle Data Provider for .NET, Managed Driver" type="Oracle.ManagedDataAccess.Client.OracleClientFactory, Oracle.ManagedDataAccess, Version=4.121.2.0, Culture=neutral, PublicKeyToken=89b483f429c47342"/>
这就是我查询 DBProviders 的方式(但提供程序列表不包含我的条目):
DataTable Providers = DbProviderFactories.GetFactoryClasses();
Providers.Select("InvariantName = 'Oracle.ManagedDataAccess.Client'");
那么为什么不使用我的应用程序配置呢?我想将我的应用程序部署到客户端。我不确定是否可以更改他们的 maschine.config。
谢谢你的帮助
更新:我终于找到了一个可能的解释:当我嵌入配置时(我喜欢这样做,因为没有理由将配置文件放在 exe 旁边)它不起作用。但是,当我将配置类型更改为“无”并将它们放在 exe 旁边时,一切正常。