使用实体框架实体连接时出现MetadataException

entity-framework

这段代码:

using (EntityConnection conn = new EntityConnection("name=ELSCommonEntities"))
{
  conn.Open();
}

给我以下错误:

Test method ELS.Service.Business.IntegrationTest.Base.ServiceBaseIntegrationTest.StartLoggingTestMethod threw exception:  System.Data.MetadataException: Unable to load the specified metadata resource..

使用以下堆栈跟踪:

System.Data.Metadata.Edm.MetadataArtifactLoaderCompositeResource.LoadResources(String assemblyName, String resourceName, ICollection`1 uriRegistry, MetadataArtifactAssemblyResolver resolver)
System.Data.Metadata.Edm.MetadataArtifactLoaderCompositeResource.CreateResourceLoader(String path, ExtensionCheck extensionCheck, String validExtension, ICollection`1 uriRegistry, MetadataArtifactAssemblyResolver resolver)
System.Data.Metadata.Edm.MetadataArtifactLoader.Create(String path, ExtensionCheck extensionCheck, String validExtension, ICollection`1 uriRegistry, MetadataArtifactAssemblyResolver resolver)
System.Data.EntityClient.EntityConnection.SplitPaths(String paths)
System.Data.EntityClient.EntityConnection.GetMetadataWorkspace(Boolean initializeAllCollections)
System.Data.EntityClient.EntityConnection.InitializeMetadata(DbConnection newConnection, DbConnection originalConnection, Boolean closeOriginalConnectionOnFailure)
System.Data.EntityClient.EntityConnection.Open()
ELS.Service.Business.Base.ServiceBase.StartLogging(String userWindowsLogon) in C:\C-TOM\ELS-RELEASE1\ELS.Service.Business\Base\ServiceBase.cs: line 98
ELS.Service.Business.IntegrationTest.Base.ServiceBaseIntegrationTest.StartLoggingTestMethod() in C:\C-TOM\ELS-RELEASE1\ELS.Service.Business.IntegrationTest\Base\ServiceBaseIntegrationTest.cs: line 65

但是,此代码使用相同的连接字符串:

using (ELSCommonEntities db = new ELSCommonEntities())
{
    var res = from c in db.Logging
              select c;

    int i = res.Count();
}

不给出错误。

连接字符串是:

<add name="ELSCommonEntities" connectionString="metadata=res://*/Common.CommonModel.csdl|res://*/Common.CommonModel.ssdl|res://*/Common.CommonModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;Data Source=localhost;Initial Catalog=els5_demo;Integrated Security=True;MultipleActiveResultSets=True&quot;" providerName="System.Data.EntityClient" />

我也在反射器中打开了dll,元数据看起来还不错。

一般承认的答案

发现了问题。

标准元数据字符串如下所示:

metadata=res://*/Model.csdl|res://*/Model.ssdl|res://*/Model.msl

这在大多数情况下都可以正常工作。但是,在某些(包括我的)实体框架中,混淆并且不知道要查看哪个dll。因此,将元数据字符串更改为:

metadata=res://nameOfDll/Model.csdl|res://nameOfDll/Model.ssdl|res://nameOfDll/Model.msl

它会奏效。正是这个链接让我走上正轨:

http://itstu.blogspot.com/2008/07/to-load-specified-metadata-resource.html

虽然我有相反的问题,但没有在单元测试中工作,但在服务中工作。


热门答案

我有相同的错误消息,问题也是连接字符串的元数据部分,但我不得不深入挖掘解决它,并希望分享这个小块:

元数据字符串由三个部分组成,每个部分如下所示:

res://
      (assembly)/
      (model name).(ext)

其中ext是“csdl”,“ssdl”和“msl”。

对于大多数人来说, 汇编可能是“*”,这似乎表明将搜索所有已加载的程序集(我没有对此进行过大量的测试)。这部分对我来说不是问题,所以我不能评论你是否需要程序集名称或文件名(即有或没有“.dll”),虽然我已经看到这两个建议。

模型名称部分应该是.edmx文件相对于程序集的名称和名称空间 。因此,如果您有一个My.DataAccess程序集并在Models文件夹中创建DataModels.edmx ,则其全名为My.DataAccess.Models.DataModels 。在这种情况下,您的元数据中将包含“Models.DataModels。(ext)”。

如果您移动或重命名.edmx文件,则需要手动更新元数据字符串(根据我的经验),并且记住更改相对命名空间会省去一些麻烦。



许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因
许可下: CC-BY-SA with attribution
不隶属于 Stack Overflow
这个KB合法吗? 是的,了解原因