我的配置类构造函数如下:
public Configuration() => AutomaticMigrationsEnabled = false;
我甚至将 DbContent 更新为:
public DatabaseContext()
: base("DefaultConnection")
{
Database.CommandTimeout = 900;
Database.Log = s => Debug.WriteLine(s);
Configuration.LazyLoadingEnabled = false;
Database.SetInitializer(new CreateDatabaseIfNotExists<DatabaseContext>());
}
但是当我尝试为特定迁移运行update-database
时:
update-database -TargetMigration CreateOrganisation
我明白了:
应用显式迁移:[201805081508118_CreateOrganisation]。
应用显式迁移:201805081508118_CreateOrganisation。
应用自动迁移:201805081508117_CreateOrganisation_AutomaticMigration。
它运行的最后一个然后失败,因为它声明:
System.Data.SqlClient.SqlException(0x80131904):数据库中已有一个名为“Answers”的对象。
有哪些,但实际的迁移看起来像这样:
public partial class CreateOrganisation : DbMigration
{
public override void Up()
{
CreateTable(
"dbo.Organisations",
c => new
{
Id = c.String(nullable: false, maxLength: 100),
Name = c.String(nullable: false, maxLength: 100),
Description = c.String(maxLength: 255),
})
.PrimaryKey(t => t.Id);
AddColumn("dbo.Users", "OrganisationId", c => c.String(maxLength: 100));
}
public override void Down()
{
DropTable("dbo.Organisations");
DropColumn("dbo.Users", "OrganisationId");
}
}
正如您所看到的,在迁移过程中没有提及答案,这导致我假设它正在尝试进行先前的迁移....
有谁知道我怎么能阻止它?
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
// Table renames
modelBuilder.Entity<Criteria>().ToTable("Criteria");
modelBuilder.Entity<Formula>().ToTable("Formulas");
modelBuilder.Entity<IdentityRole>().ToTable("Roles");
modelBuilder.Entity<IdentityUserRole>().ToTable("UserRoles");
modelBuilder.Entity<IdentityUserClaim>().ToTable("UserClaims");
modelBuilder.Entity<IdentityUserLogin>().ToTable("UserLogins");
modelBuilder.Entity<ImageText>().ToTable("ImageText");
// One to Many
modelBuilder.Entity<Criteria>().HasMany(m => m.Attributes).WithOptional().HasForeignKey(m => m.CriteriaId);
modelBuilder.Entity<IdentityRole>().HasMany(m => m.Users).WithRequired().HasForeignKey(m => m.RoleId);
modelBuilder.Entity<Organisation>().HasMany(m => m.Feeds).WithRequired().HasForeignKey(m => m.OrganisationId);
modelBuilder.Entity<Organisation>().HasMany(m => m.Users).WithRequired().HasForeignKey(m => m.OrganisationId);
modelBuilder.Entity<Group>().HasMany(m => m.Questions).WithOptional().HasForeignKey(m => m.GroupId);
modelBuilder.Entity<Question>().HasMany(m => m.Answers).WithOptional().HasForeignKey(m => m.QuestionId);
modelBuilder.Entity<Category>().HasMany(m => m.PriorityColours).WithRequired().HasForeignKey(m => m.CategoryId);
modelBuilder.Entity<Category>().HasMany(m => m.Criteria).WithRequired().HasForeignKey(m => m.CategoryId);
modelBuilder.Entity<Category>().HasMany(m => m.Feeds).WithRequired().HasForeignKey(m => m.CategoryId);
modelBuilder.Entity<Category>().HasMany(m => m.Quotes).WithRequired().HasForeignKey(m => m.CategoryId);
modelBuilder.Entity<Category>().HasMany(m => m.QuestionGroups).WithRequired().HasForeignKey(m => m.CategoryId);
modelBuilder.Entity<User>().HasMany(m => m.Searches).WithRequired().HasForeignKey(m => m.UserId);
modelBuilder.Entity<User>().HasMany(m => m.Charges).WithRequired().HasForeignKey(m => m.UserId);
modelBuilder.Entity<Answer>().HasMany(m => m.Images).WithRequired().HasForeignKey(m => m.AnswerId);
modelBuilder.Entity<Image>().HasMany(m => m.ImageText).WithRequired().HasForeignKey(m => m.ImageId);
// Create our primary keys
modelBuilder.Entity<IdentityUserLogin>().HasKey(m => m.UserId);
modelBuilder.Entity<IdentityRole>().HasKey(m => m.Id);
modelBuilder.Entity<IdentityUserRole>().HasKey(m => new {m.RoleId, m.UserId});
}
根据要求
答案 0 :(得分:0)
您似乎遇到了和我一样的问题,我在下面的链接中找到了答案,它对我有用,希望对您也有用:
Update-Database tries to do an automatic migration even with automatic migrations disabled
我将答案复制到此处的必要部分
实体框架将始终运行自动迁移,然后再运行在其.resx文件中定义了Source属性的显式迁移,即使AutomaticMigrationsEnabled = false。如果显式迁移是在运行自动迁移后创建的,则仅会设置Source属性。
结果是,禁用自动迁移仅意味着EF在检测到模型更改时不会自动升级架构-但如果它需要填补某些显式迁移之间的空白,它可能仍会进行自动迁移。为避免这种情况,请勿同时使用自动迁移和显式迁移。
接下来的步骤就是我为解决此问题所做的事情:
update-database -verbose
。