c# - एंटिटी फ्रेमवर्क 6.1.3 "एक प्रकार का लोड क्यों नहीं कर सका" System.Data.Entity.Infrastructure.TableExistenceChecker '




.net entity-framework (8)

SQL Studio का उपयोग करने वाले इकाई परीक्षण चलाते समय Visual Studio 2015 (VS 2015) को स्थापित करने के बाद मुझे यही त्रुटि मिल रही थी। मेरा कनेक्शन कारखाना SqlCeConnectionFactory और प्रदाता System.Data.Entity.SqlServerCompact.SqlCeProviderServices , EntityFramework.SqlServerCompact

मेरे लिए समाधान यह था कि EntityFramework.SqlServerCompact.dll में पथ को मेरी तैनाती फ़ाइल में तैनाती सूची में .testsettings । मैंने जो लाइन जोड़ी वह इस प्रकार है:

<DeploymentItem filename="packages\EntityFramework.SqlServerCompact.6.1.1\lib\net45\EntityFramework.SqlServerCompact.dll" />

ब्रांड नई परियोजना और इकाई रूपरेखा अपवाद उदाहरण के बनते ही फेंके जाने के कारण शुरू नहीं होगी।

इकाई ढांचा निम्नलिखित अपवाद फेंकता है:

असेंबली 'EntityFramework, संस्करण = 6.0.0.0, संस्कृति = तटस्थ, PublicKeyToken = b77a5x561934e089' से 'System.Data.Entity.Infrastructure.TableExistenceChecker' लोड नहीं किया जा सका।

संदर्भ:

  • इकाई की रूपरेखा
  • EntityFramework.SqLServer

नगेट पैकेज मैनेजर के माध्यम से:

Install-Package entityframework

बहुत ही सरल संदर्भ और इकाई:

public class TextDbContext : DbContext
{
    public TextDbContext()
        : base("Test")
    {
    }

    public DbSet<TestEntity> TestEntity { get; set; }
}

public class TestEntity
{
    public int Id { get; set; } 
    public string Name { get; set; }
}

static void Main(string[] args)
{
    var test = ConfigurationManager.ConnectionStrings["Test"].ConnectionString;

    using (var conn = new SqlConnection(test))
    {
        conn.Open();
        var cmd = new SqlCommand("Select * from testtable", conn);
        var result = cmd.ExecuteReader();
    }
    //exception thrown on this line is the same as the one in the context
    var instance = SqlProviderServices.Instance;

    using (var db = new TextDbContext())
    {
         var item = new TestEntity
         {
             Name = "xyz"
         };
         db.TestEntity.Add(item);
         db.SaveChanges();
    }
}

यहाँ वर्तमान app.config फ़ाइल है:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
    <configSections>
        <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral,  PublicKeyToken=b77a5c561934e089" requirePermission="false" />
    </configSections>
    <connectionStrings>
        <add name="Test" connectionString="server=localhost;database=Test;Data Source=localhost;Integrated Security=True;Pooling=True" providerName="System.Data.SqlClient" />
    </connectionStrings>
    <startup>
       <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" />
    </startup>
    <entityFramework>
        <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
         <providers>
            <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
        </providers>
    </entityFramework>
</configuration>

स्टैक ट्रेस निम्नानुसार है:

   at System.RuntimeMethodHandle.InvokeMethod(Object target, Object[] arguments, Signature sig, Boolean constructor)
   at System.Reflection.RuntimeMethodInfo.UnsafeInvokeInternal(Object obj, Object[] parameters, Object[] arguments)
   at System.Reflection.RuntimeMethodInfo.Invoke(Object obj, BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
   at System.Reflection.RuntimePropertyInfo.GetValue(Object obj, BindingFlags invokeAttr, Binder binder, Object[] index, CultureInfo culture)
   at System.Reflection.RuntimePropertyInfo.GetValue(Object obj, Object[] index)
   at System.Data.Entity.Utilities.MemberInfoExtensions.GetValue(MemberInfo memberInfo)
   at System.Data.Entity.Infrastructure.DependencyResolution.ProviderServicesFactory.GetInstance(Type providerType)
   at System.Data.Entity.Infrastructure.DependencyResolution.ProviderServicesFactory.GetInstance(String providerTypeName, String providerInvariantName)
   at System.Data.Entity.Internal.AppConfig.<.ctor>b__2(ProviderElement e)
   at System.Linq.Enumerable.WhereSelectEnumerableIterator`2.MoveNext()
   at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)
   at System.Linq.Enumerable.ToList[TSource](IEnumerable`1 source)
   at System.Data.Entity.Internal.AppConfig.<.ctor>b__1()
   at System.Lazy`1.CreateValue()
   at System.Lazy`1.LazyInitValue()
   at System.Lazy`1.get_Value()
   at System.Data.Entity.Internal.AppConfig.get_DbProviderServices()
   at System.Data.Entity.Infrastructure.DependencyResolution.AppConfigDependencyResolver.RegisterDbProviderServices()
   at System.Data.Entity.Infrastructure.DependencyResolution.AppConfigDependencyResolver.GetServiceFactory(Type type, String name)
   at System.Data.Entity.Infrastructure.DependencyResolution.AppConfigDependencyResolver.<>c__DisplayClass1.<GetService>b__0(Tuple`2 t)
   at System.Collections.Concurrent.ConcurrentDictionary`2.GetOrAdd(TKey key, Func`2 valueFactory)
   at System.Data.Entity.Infrastructure.DependencyResolution.AppConfigDependencyResolver.GetService(Type type, Object key)
   at System.Data.Entity.Infrastructure.DependencyResolution.DbDependencyResolverExtensions.GetServiceAsServices(IDbDependencyResolver resolver, Type type, Object key)
   at System.Data.Entity.Infrastructure.DependencyResolution.AppConfigDependencyResolver.GetServices(Type type, Object key)
   at System.Data.Entity.Infrastructure.DependencyResolution.ResolverChain.<>c__DisplayClass6.<GetServices>b__5(IDbDependencyResolver r)
   at System.Linq.Enumerable.<SelectManyIterator>d__14`2.MoveNext()
   at System.Linq.Enumerable.<ConcatIterator>d__71`1.MoveNext()
   at System.Linq.Enumerable.<OfTypeIterator>d__aa`1.MoveNext()
   at System.Data.Entity.Utilities.IEnumerableExtensions.Each[T](IEnumerable`1 ts, Action`1 action)
   at System.Data.Entity.Infrastructure.DependencyResolution.InternalConfiguration.Lock()
   at System.Data.Entity.Infrastructure.DependencyResolution.DbConfigurationManager.<.ctor>b__1()
   at System.Lazy`1.CreateValue()
   at System.Lazy`1.LazyInitValue()
   at System.Lazy`1.get_Value()
   at System.Data.Entity.Infrastructure.DependencyResolution.DbConfigurationManager.GetConfiguration()
   at System.Data.Entity.DbContext.InitializeLazyInternalContext(IInternalConnection internalConnection, DbCompiledModel model)
   at System.Data.Entity.DbContext..ctor(String nameOrConnectionString)
   at test2.TextDbContext..ctor() in \\srv\users\carl.tierney\Documents\Visual Studio 2013\Projects\test2\test2\test2context.cs:line 13
   at test2.Program.Main(String[] args) in \\srv\users\carl.tierney\Documents\Visual Studio 2013\Projects\test2\test2\Program.cs:line 13
   at System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
   at System.AppDomain.ExecuteAssembly(String assemblyFile, Evidence assemblySecurity, String[] args)
   at Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
   at System.Threading.ThreadHelper.ThreadStart_Context(Object state)
   at System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
   at System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state
   at System.Threading.ThreadHelper.ThreadStart()

क्या आपके पास EntityFramework.SqlServer संदर्भित है? यह इकाई ढांचे के साथ स्वचालित रूप से आना चाहिए। यदि इसे संदर्भ के रूप में या नुगेट के माध्यम से जोड़ने का प्रयास न करें।

यदि आप SqlServer प्रदाता का उपयोग कर रहे हैं, तो संभोग करें। यदि नहीं, तो आपको अपना विशिष्ट प्रदाता जोड़ने की आवश्यकता है।


बस अपने उपयोग के EF संस्करण से मेल करने के लिए package.config फ़ाइल को अपडेट करें इस मामले में, यह "6.1.3" है।


मुझे अपनी इकाई परीक्षण परियोजना में ठीक यही समस्या थी। समस्या निवारण के कुछ घंटों के बाद मैंने देखा कि .csproj-file में अभी भी EF के मेरे पिछले संस्करण का संदर्भ था:

<Reference Include="EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=MSIL">
    <SpecificVersion>False</SpecificVersion>
    <HintPath>..\packages\EntityFramework.6.1.1\lib\net45\EntityFramework.dll</HintPath>
</Reference>

मैंने बस संस्करण को 6.1.3 में बदल दिया और सभी परीक्षण फिर से ठीक हो गए।


मेरे मामले में भविष्य के संदर्भ के लिए GAC से EntityFramework.SqlServer को EntityFramework.SqlServer इस त्रुटि को ठीक किया गया। असेंबली मेरे आवेदन में संदर्भित एक से बिल्कुल समान संस्करण थी ( EntityFramework.dll और EntityFramework.SqlServer.dll दोनों के लिए EntityFramework.SqlServer.dll )। हालाँकि, मेरे पास GAC में EntityFramework नहीं था जब यह अपवाद हुआ।

मैंने NuGet का उपयोग करते हुए SQLite Core (x86 / x64) के साथ अपने आवेदन में EntityFramework संदर्भ स्थापित किया था। इसके अलावा, मैंने जीएसी के साथ थोड़ी देर पहले डब किया था और सबसे अधिक संभावना है कि वहां खुद विधानसभा को जोड़ा।


मेरे मामले में मुझे इस फ़ोल्डर से EntityFramework.dll को निकालना पड़ा:

C:\Windows\Microsoft.NET\assembly\GAC_MSIL\EntityFramework

वही समस्या मुझे हुई

विज़ुअल स्टूडियो खोलें -> उपकरण -> एक्सटेंशन और अपडेट

  1. यदि Nuget Package Manager कंसोल से संबंधित कोई भी अपडेट अपडेट करता है, तो अपडेट को पहले देखें।

  2. एक्सटेंशन और अपडेट में सभी टैब का चयन करें सुनिश्चित करें कि आपका नगेट पैकेज मैनेजर कंसोल संस्करण है

  1. अपने प्रोजेक्ट फोल्डर को खोलें -> पैकेज फिर एंटिटीफ्रैमवर्क के बारे में सब कुछ हटा दें

  2. अगर कोई फ़ाइल है जैसे कि Unitframework.deleteme -> इसे हटा दें और Visual Studio को पुनरारंभ करें


से बदलते मूल्य

"data source=.;initial catalog=[dbname];integrated security=True"

सेवा मेरे

"Server=.;Database=[dbname];integrated security=True"




entity-framework-6