Код EF 6 Первая миграция с конвенциями
Я ссылался на еще один вопрос SO, чтобы переименовать мои свойства внешнего ключа в соответствии с соглашением, которое я хочу.
Как убрать подчеркивание полей внешнего ключа в коде первым по соглашению
Я обнаружил, что эти соглашения соблюдаются только во время выполнения и не используются при первом переносе кода в леса.
Это избавило бы меня от необходимости настраивать каждую сгенерированную миграцию, если бы она соответствовала моим правилам именования FK.
Для справки:
public class ApplicationUser : AbstractEntity
{
public EmailAddress PrimaryEmail { get; set; }
}
public class EmailAddress : AbstractEntity
{
public string Value { get; set; }
}
public class MyDbContext : DbContext
{
protected override void OnModelCreating(DbModelBuilder mb)
{
mb.Conventions.AddBefore<ForeignKeyIndexConvention>(new MyForeignKeyNamingConvention());
mb.Conventions.Remove<PluralizingTableNameConvention>();
//complex types here
mb.Configurations.Add(new PersonNameConfiguration());
//entity types here
mb.Configurations.Add(new ApplicationUserConfiguration());
mb.Configurations.Add(new EmailAddressConfiguration());
base.OnModelCreating(mb);
}
public IDbSet<ApplicationUser> Users { get; set; }
}
Так что для вышеупомянутых предметов и показанного контекста я иду, чтобы подготовить миграцию, чтобы добавить таблицу электронной почты. Это создает следующее:
public partial class CreateEmailAddresses : DbMigration
{
public override void Up()
{
CreateTable(
"dbo.EmailAddress",
c => new
{
Id = c.Int(nullable: false, identity: true),
Value = c.String(nullable: false, maxLength: 1023),
IsRemoved = c.Boolean(nullable: false),
CreatedDate = c.DateTimeOffset(nullable: false, precision: 7),
ModifiedDate = c.DateTimeOffset(precision: 7),
RemovedDate = c.DateTimeOffset(precision: 7),
})
.PrimaryKey(t => t.Id);
AddColumn("dbo.ApplicationUser", "PrimaryEmail_IdValue", c => c.Int(nullable: false));
CreateIndex("dbo.ApplicationUser", "PrimaryEmail_IdValue");
AddForeignKey("dbo.ApplicationUser", "PrimaryEmail_IdValue", "dbo.EmailAddress", "Id", cascadeDelete: true);
}
public override void Down()
{
DropForeignKey("dbo.ApplicationUser", "PrimaryEmail_IdValue", "dbo.EmailAddress");
DropIndex("dbo.ApplicationUser", new[] { "PrimaryEmail_IdValue" });
DropColumn("dbo.ApplicationUser", "PrimaryEmail_IdValue");
DropTable("dbo.EmailAddress");
}
}
Однако я тестировал во время выполнения, и соглашение об именах внешних ключей действительно используется и работает так, как я хочу. Но часть лесов EF этого не видит.
Я просто что-то смотрю?
Чтобы быть понятным, я хочу, чтобы миграция генерировала имена внешних ключей без "_" в имени.