Корпоративная библиотека DAAB 6 и ODP.NET - строка подключения для базы данных по умолчанию 'XXX' не существует
Я использую корпоративную библиотеку DAAB 6. Для связи с базой данных Oracle я использую библиотеку EntLib Contrib.
Файл конфигурации моего приложения выглядит так
<configuration>
<configSections>
<section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=6.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" requirePermission="true" />
</configSections>
<dataConfiguration defaultDatabase="OracleConnectionString">
<providerMappings>
<add databaseType="EntLibContrib.Data.OdpNet.OracleDatabase, EntLibContrib.Data.OdpNet, Version=6.0.0.0, Culture=neutral, PublicKeyToken=null"
name="Oracle.DataAccess.Client" />
</providerMappings>
</dataConfiguration>
<connectionStrings>
<add name="OracleConnectionString" connectionString="Data Source=localhost:1521/dev;User ID=db_owner;Password=admin;"
providerName="Oracle.DataAccess.Client" />
</connectionStrings>
<configuration>
Я установил все необходимые пакеты, используя NuGet. Файл Package.Config выглядит так:
<packages>
<package id="EnterpriseLibrary.Common" version="6.0.1304.0" targetFramework="net45" />
<package id="EnterpriseLibrary.Data" version="6.0.1304.0" targetFramework="net45" />
<package id="EntLibContrib.Data.OdpNet" version="6.0.1304.0" targetFramework="net45" />
</packages>
Я также добавил ссылку на файл Oracle.DataAccess.dll.
Я подключаюсь к базе данных, используя следующую строку кода
var database = new DatabaseProviderFactory().CreateDefault();
Приведенная выше строка генерирует очень странное сообщение об ошибке. Полная трассировка стека приведена ниже:
System.InvalidOperationException: The connection string for the default database 'OracleConnectionString' does not exist or does not have a valid provider.
---> System.Configuration.ConfigurationErrorsException: The requested database OracleConnectionString does not have a valid ADO.NET provider name set in the connection string. (C:\Test\OraConsole\bin\Debug\OraConsole.vshost.exe.Config line 13)
at Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSyntheticConfigSettings.GetDatabase(String name)
at Microsoft.Practices.EnterpriseLibrary.Data.DatabaseProviderFactory.DatabaseConfigurationBuilder.<CreateDefault>b__2(String n)
--- End of inner exception stack trace ---
at Microsoft.Practices.EnterpriseLibrary.Data.DatabaseProviderFactory.DatabaseConfigurationBuilder.<CreateDefault>b__2(String n)
at System.Collections.Concurrent.ConcurrentDictionary`2.GetOrAdd(TKey key, Func`2 valueFactory)
at Microsoft.Practices.EnterpriseLibrary.Data.DatabaseProviderFactory.DatabaseConfigurationBuilder.CreateDefault()
at Microsoft.Practices.EnterpriseLibrary.Data.DatabaseProviderFactory.CreateDefault()
at Data.OdpNet.QuickStarts.Console.Program.Main(String[] args) in c:\Test\OraConsole\Program.cs:line 15
tnsping отлично работает для базы данных Oracle.
Я нашел это конкретное сообщение об ошибке, но не могу найти решение этой проблемы. Я также попробовал образец кода QuickStart, доступный с источником Contrib. Это также генерирует то же самое сообщение об ошибке.
1 ответ
Похоже, DbProviderFactories не настроен для Oracle. Обычно при установке ODP.NET конфигурация машины обновляется примерно так:
<system.data>
<DbProviderFactories>
<add name="Oracle Data Provider for .NET Version 11.1.0.6.0"
invariant="Oracle.DataAccess.Client Version 11.1.0.6.0"
description="Oracle Data Provider for .NET Version 11.1.0.6.0"
type="Oracle.DataAccess.Client.OracleClientFactory, Oracle.DataAccess,
Version=2.111.6.0, Culture=neutral, PublicKeyToken=89b483f429c47342" />
</DbProviderFactories>
</system.data>
См. Конфигурация ODP.NET. Я бы подтвердил, что machine.config настроен. Вы также можете настроить provderfactories в вашем app/web.config.