У меня есть Конфигурация конструктор класса, подобный этому:
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.
Последний выполняется, затем завершается сбоем, так как он сообщает:
* 1026System.Data.SqlClient.SqlException (0x80131904): В базе данных уже есть объект с именем «Ответы».
Да, но фактическая миграция выглядит следующим образом:
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});
}
По запросу