app.config не работает при добавлении записи DbProviderFactories для ODP.NET
Я пытаюсь использовать 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), это не работает. Но когда я изменяю тип конфигурации на "ничего" и помещаю их рядом с исполняемым файлом, все работает нормально.
1 ответ
С этой конфигурацией это наконец работает:
<configuration>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2"/>
</startup>
<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>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<publisherPolicy apply="no"/>
<assemblyIdentity name="Oracle.ManagedDataAccess" publicKeyToken="89b483f429c47342" culture="neutral"/>
<bindingRedirect oldVersion="4.121.0.0 - 4.65535.65535.65535" newVersion="4.121.2.0"/>
</dependentAssembly>
</assemblyBinding>
</runtime>
</configuration>