禁用实体框架中的自动迁移

时间:2018-06-04 11:43:00

标签: c# entity-framework

我的配置类构造函数如下:

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});
}

根据要求

1 个答案:

答案 0 :(得分:0)

您似乎遇到了和我一样的问题,我在下面的链接中找到了答案,它对我有用,希望对您也有用:

Update-Database tries to do an automatic migration even with automatic migrations disabled

我将答案复制到此处的必要部分

  

实体框架将始终运行自动迁移,然后再运行在其.resx文件中定义了Source属性的显式迁移,即使AutomaticMigrationsEnabled = false。如果显式迁移是在运行自动迁移后创建的,则仅会设置Source属性。

     

结果是,禁用自动迁移仅意味着EF在检测到模型更改时不会自动升级架构-但如果它需要填补某些显式迁移之间的空白,它可能仍会进行自动迁移。为避免这种情况,请勿同时使用自动迁移和显式迁移。

接下来的步骤就是我为解决此问题所做的事情:

  • 找到丢失的迁移文件的resx文件
  • 打开它并删除源属性。最好可以复制此resx文件。
  • 再次运行命令update-database -verbose
  • 即将进行的迁移将添加到_migrationHistory表中。
相关问题