在.Net 使用EF如果不正确,可能会出现异常错误。一般而言,有可能以下错误场景
1,在程序集“XXX”中未找到迁移配置类型“XXX.Migrations.Configuration”。
这种错误出现在定义的DBContext 类与定义的web.config 数据连接串名称不一致,应将两者保持一致。如下面所示
配置文件:
<add name="MusicStoreEntities" connectionString=" Data Source=.;Initial Catalog=test;User ID=test;Password=test;"
类文件:
public class MusicStoreEntities : DbContext
{
public DbSet<Album> Albums { get; set; }
public DbSet<Genre> Genres { get; set; }
}
2,The project 'XXXX' failed to build.
有时在Visio studio 中的“程序包管理器控制台”中执行update-database 会出现如下类似错误
The project 'MvcApplication1' failed to build.
工程编译错误
这种情况一般是因为程序自身有明显的编译问题,可编译工程发现具体错误在什么位置。
3,无法将数据库更新为与当前模型匹配,因为存在待定更改并且禁用了自动迁移。将待定模型更改写入基于代码的迁移或启用自动迁移。将 DbMigrationsConfiguration.AutomaticMigrationsEnabled 设置为 true 以启用自动迁移。
这种情况一般是在工程内的Migrations 文件夹中的Configuration.cs 文件没有定义AutomaticMigrationsEnabled属性为true导致。可修改如下
public Configuration()
{
AutomaticMigrationsEnabled = true;
}
在文件内容显示为AutomaticMigrationsEnabled=true 时,有时也会报这类错误。这往往是因为执行了enable-migrations -force 强制修改了这类文件导致,文件显示信息已与工程实际信息不一致,对Configuration.cs 文件关闭再打开,即可发现AutomaticMigrationsEnabled=false
4,不支持关键字: “XXX”。
这种问题,有可能发生在web.config 的数据库连接配置字符串信息,正确形式可如下所示
connectionString="Data Source=.;Initial Catalog=test;User ID=test;pwd=test" />