Код 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 этого не видит.

Я просто что-то смотрю?

Чтобы быть понятным, я хочу, чтобы миграция генерировала имена внешних ключей без "_" в имени.

0 ответов

Другие вопросы по тегам