7

Я использую ODP.NET и версию 4.1 Enterprise Library, против 2008 года. И все в порядке.Тип базы данных не может быть сконструирован. Вы должны настроить контейнер для поставки этого значения (EntLib 5 + ODP.NET)

Теперь перейдите с использованием ODP.NET Oracle.DataAccess 4.112.2.0 и версии 5.0.414.0 из Enterprise Library, vs 2010, .net 4.0.

Oracle.DataAccess 4.112.2.0 EnterpriseLibrary 5.0.414.0

После недавнего обновления с версии 4.1 до 5.0 библиотеки Enterprise, как только мы получим следующее сообщение об ошибке:

«База данных типа не может быть Вы должны сконфигурировать контейнер для подачи этого значения ».

Microsoft.Practices.ServiceLocation.ActivationException: Activation error occured while trying to get instance of type Database, key "ConnectionStrings.Oracle.xxx" ---> Microsoft.Practices.Unity.ResolutionFailedException: Resolution of the dependency failed, type = "Microsoft.Practices.EnterpriseLibrary.Data.Database", name = "ConnectionStrings.Oracle.xxx". Exception occurred while: while resolving. Exception is: InvalidOperationException - The type Database cannot be constructed. You must configure the container to supply this value.

Ссылки EntLib Форум: http://entlib.codeplex.com/discussions/215290

любое решение по этому поводу ??

мой конфиг

<configSections> 

<section name="loggingConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Logging.Configuration.LoggingSettings, Microsoft.Practices.EnterpriseLibrary.Logging, Version=5.0.414.0, Culture=neutral, PublicKeyToken=709072f976b4c05b"/> 

<section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings,Microsoft.Practices.EnterpriseLibrary.Data, Version=5.0.414.0, Culture=neutral, PublicKeyToken=709072f976b4c05b" /> 
</configSections> 

<dataConfiguration defaultDatabase="ConnectionStrings.Oracle.xxx"/> 

<connectionStrings> 

<add name="ConnectionStrings.Oracle.xxx" connectionString="DATA SOURCE=des;PASSWORD=zzz;PERSIST SECURITY INFO=True;USER ID=aaa;" 
providerName="Oracle.DataAccess.Client" /> 

Мой код

var key = "ConnectionStrings.Oracle.xxx"; 

      Database db = Microsoft.Practices.EnterpriseLibrary.Common.Configuration.EnterpriseLibraryContainer.Current.GetInstance<Database>(key); //~(EntLib 5 recommended) 


      using (DbCommand cm = db.GetStoredProcCommand("TBL_FRKDATA.TBL_FRKDATA_FND_ALL")) 
      { 
       cm.Parameters.Add(CreateCursorParameter("P_REFCURSOR")); 

       // Using "using" will cause both the DataReader and connection to be 
       // closed. (ExecuteReader will close the connection when the 
       // DataReader is closed.) 
       using (IDataReader dataReader = db.ExecuteReader(cm)) 
       { 
        while (dataReader.Read()) 
        { 
         builder.Add(dataReader); 
        } 
        return builder.EntityList; 

       } 
      } 

полная ошибка StackTrace

Microsoft.Practices.ObjectBuilder2.DynamicMethodConstructorStrategy.GuardTypeIsNonPrimitive(IBuilderContext context, SelectedConstructor selectedConstructor) Microsoft.Practices.ObjectBuilder2.DynamicMethodConstructorStrategy.PreBuildUp(IBuilderContext context) Microsoft.Practices.ObjectBuilder2.StrategyChain.ExecuteBuildUp(IBuilderContext context) Microsoft.Practices.ObjectBuilder2.DynamicMethodBuildPlanCreatorPolicy.CreatePlan(IBuilderContext context, NamedTypeBuildKey buildKey) Microsoft.Practices.ObjectBuilder2.BuildPlanStrategy.PreBuildUp(IBuilderContext context) Microsoft.Practices.ObjectBuilder2.StrategyChain.ExecuteBuildUp(IBuilderContext context) Microsoft.Practices.Unity.UnityContainer.DoBuildUp(Type t, Object existing, String name, IEnumerable 1 resolverOverrides) Microsoft.Practices.Unity.UnityContainer.DoBuildUp(Type t, Object existing, String name, IEnumerable 1 resolverOverrides) Microsoft.Practices.Unity.UnityContainer.Resolve(Type t, String name, ResolverOverride[] resolverOverrides) Microsoft.Practices.Unity.UnityServiceLocator.DoGetInstance(Type serviceType, String key) Microsoft.Practices.ServiceLocation.ServiceLocatorImplBase.GetInstance(Type serviceType, String key) Microsoft.Practices.ServiceLocation.ServiceLocatorImplBase.GetInstance(Type serviceType, String key) Microsoft.Practices.ServiceLocation.ServiceLocatorImplBase.GetInstance[TService](String key)

UPDATE

этот код работает для меня:

[TestMethod] 
    public void Conectar_con_EntLib_y_OdpNet_Test() 
    { 
     var key = "ConnectionStrings.Oracle.xxx"; 

     string connectionString = ConfigurationManager.ConnectionStrings[key].ConnectionString; 
     string providerName = ConfigurationManager.ConnectionStrings[key].ProviderName; 

     //Database db = Microsoft.Practices.EnterpriseLibrary.Common.Configuration.EnterpriseLibraryContainer.Current.GetInstance<Database>(key); 

     TestContext.WriteLine("connectionString: " + connectionString); 
     TestContext.WriteLine("providerName: " + providerName); 

     DbProviderFactory factory = DbProviderFactories.GetFactory(providerName); 

     using (DbConnection connection = factory.CreateConnection()) 
     { 
      connection.ConnectionString = connectionString; 

      connection.Open(); 

      TestContext.WriteLine("Estado Conexión: " + connection.State); 
      connection.Close(); 
     } 



    } 

Решение: Рэнди Леви (http://entlib.codeplex.com/discussions/215290)

Вы не можете использовать Enterprise Library OracleDatabase с провайдером Oracle.DataAccess.Client. Встроенная OracleDatabase жестко запрограммирована на , используя OracleClientFactory DbProviderFactory, тогда как вы хотите использовать поставщика ODP.NET (Oracle.DataAccess.Client).

Лучший способ получить доступ к поставщику данных Oracle ODP.NET Oracle EntLibContrib, поскольку он должен поддерживать все, что вам нужно, включая файлы конфигурации.

Поскольку похоже, что вы можете создать DbProviderFactory, вы можете попробовать использовать GenericDatabase с ODP.NET OracleClientFactory, но я бы предположил, что у вас возникнут проблемы с конкретными функциональными возможностями Oracle (например, refcursor).

Вы можете использовать его непосредственно:

string connectionString = ConfigurationManager.ConnectionStrings["Connection String"].ConnectionString; 
string providerName = ConfigurationManager.ConnectionStrings["Connection String"].ProviderName; 

DbProviderFactory factory = DbProviderFactories.GetFactory(providerName); 
var db = new GenericDatabase(connectionString, factory); 
+0

Быстрая проверка [сообщение MSDN] (http://msdn.microsoft.com/en-us/library/ff953187 (v ​​= PandP.50) .aspx). Государства «Однако имейте в виду, что поставщик OracleClient устарел в версии 4.0 .NET Framework, хотя он по-прежнему поддерживается корпоративной библиотекой. Для будущего развития подумайте о выборе другого драйвера Oracle. « –

+0

Вы проверили http://stackoverflow.com/questions/4030436/activation-error-occured-while-trying-to-get-instance-of-type-database- ключ или http://stackoverflow.com/questions/2900403/activation-error-occured-while-trying-to-get-instance-of-type-logwriter –

+0

System.Data.OracleClient.dll устарел в .NET 4.0. Но ODP.NET (Oracle.DataAccess.dll) поддерживается в .NET 4.0. Вопрос заключается в использовании Oracle.DataAccess.dll 4.112.2.0 и EntLib 5.0. – Kiquenet

ответ

2

Добавить ссылку на

Microsoft.Practices.EnterpriseLibrary.Common 
Microsoft.Practices.EnterpriseLibrary.Data 
Microsoft.Practices.ServiceLocation 

затем использовать эту линию, чтобы получить базу данных:

var database = EnterpriseLibraryContainer.Current.GetInstance<Database>(); 

Больше информации здесь: http://devstuffs.wordpress.com/2012/03/13/enterprise-library-5-with-odp-net/

0

У меня была та же проблема и я решил изменить пул приложений «Включить 32-разрядные приложения» на true.