EF6,Code-First,enable-migrations,“无法加载指定的元数据资源”

时间:2013-11-06 17:12:53

标签: entity-framework code-first ef-migrations entity-framework-6

我创建了一个带有3个实体类的C#类库和一个用于代码优先生成数据库的DbContext。所有版本都很顺利。我创建了一个单独的测试库,带有DbContext类的类库已按预期运行。

现在,我想使其中一个字段成为必需字段,并遵循代码优先约定,我在实体类中为属性添加了[Required]属性。下一步是启用迁移。

我转到了程序包管理器控制台,输入了“启用 - 迁移”并且... ... ...“无法加载指定的元数据资源”。

作为参考,我的DbContext类包括:

public OrganisationsContext()
    : base("Leegz_Entities_Organisations")
{
    this.Configuration.LazyLoadingEnabled = false;
    this.Configuration.ProxyCreationEnabled = false;
}

public DbSet<Organisation> Organisations { get; set; }
public DbSet<Member> Members { get; set; }
public DbSet<LeegzUser> LeegzUsers { get; set; }

我的app.config包含:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <configSections>
    <!-- For more information on Entity Framework configuration, visit http://go.microsoft.com/fwlink/?LinkID=237468 -->
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
  </configSections>
  <entityFramework>
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.LocalDbConnectionFactory, EntityFramework">
      <parameters>
        <parameter value="v11.0" />
      </parameters>
    </defaultConnectionFactory>
    <providers>
      <provider invariantName="System.Data.SqlClient" type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer" />
    </providers>
  </entityFramework>
  <connectionStrings>
    <add name="Leegz_Entities_Organisations" connectionString="data source=NEIL-INSPIRON\NEILDEV;initial catalog=TheLeegz;integrated security=True" providerName="System.Data.SqlClient" />
  </connectionStrings>
  <appSettings>
    <add key="Leegz.Entities.Organisations.DbSecuritySchema" value="Leegz.Entities.Organisations"/>
  </appSettings>
</configuration>

我已经看过很多关于这个主题的主题,但他们似乎都在谈论EDMX模型文件的参考元素中的错误。但是,因为我已经使用了代码优先,我没有模型(也许我在这里错过了一步),所以我在连接字符串中看到的关于EDMX信息的建议似乎不大适用于我。

请问任何想法?

3 个答案:

答案 0 :(得分:23)

我有类似的问题,但结果不同。由于调试花费了太多时间,因此这里有一些提示。

  1. &#34;无法加载指定的元数据资源。&#34;错误与您的连接字符串有关。
  2. 首先检查项目中包含所有实体的连接字符串。
  3. 确保连接字符串用于代码优先方法,而不是模型优先数据库优先方法(请参阅下面的示例)
  4. 在解决方案中的所有项目中重复这些步骤,其中您有与DbContext相关的连接字符串。
  5. 然后,重试Enable-Migrations命令,它应该可以正常工作。
  6. 建模第一个连接字符串示例:

    <add name="MyContext" 
        connectionString="metadata=res://*/MyModel.csdl|res://*/MyModel.ssdl|res://*/MyModel.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=.;initial catalog=MY_DB;integrated security=True;MultipleActiveResultSets=True;App=EntityFramework&quot;" 
        providerName="System.Data.EntityClient" />
    

    代码第一个连接字符串示例:

    <add name="MyContext" 
        connectionString="Data Source=.;Initial Catalog=MY_DB;Integrated Security=True;MultipleActiveResultSets=True" 
        providerName="System.Data.SqlClient"/>
    

答案 1 :(得分:5)

  1. 如果解决方案中有多个项目,请确保在包管理器控制台窗口中已选择带有dbContext的项目。
  2. 迁移使用名称等于DbContext类的connectionString。在你的情况下,它是OrganisationsContext,但不是Leegz_Entities_Organisations。

答案 2 :(得分:0)

从EF 4/5/6 model-first / database-first切换到代码优先时,我忽略了删除\ bin和\ obj文件夹,并在迁移和读取数据时遇到了同样的错误。在那之后,这个错误就消失了。

将模型优先/数据库优先改为代码优先:

  1. 将连接字符串从EF(包含元数据信息)更改为传统的ADO。
  2. 删除EDMX文件和所有子文件(.tt,.cs模型等)
  3. 删除项目的\ bin和\ _obj。
  4. 此时您的项目应该处于代码优先模式。