Entity Framework Code First CTP4 Значения столбца по умолчанию? - PullRequest
12 голосов
/ 27 октября 2010

Я изучал Code First с Entity Framework CTP4, и вы можете использовать ModelBuilder для построения столбцов таблицы.Есть ли способ установить значение по умолчанию для столбца в базе данных, используя ModelBuilder или какой-либо другой механизм?

Спасибо!

Ответы [ 4 ]

37 голосов
/ 17 февраля 2011

Я использую конструктор для установки значений по умолчанию. Никогда не подводил меня

public class Activity
{
    [Required]
    public DateTime AddedDate { get; set; }

    public Activity()
    {
        AddedDate = DateTime.Now;
    }
}
4 голосов
/ 03 мая 2013

В коде, созданном для миграции, вы можете указать значение по умолчанию для столбца:

AddColumn("users", "ReceiveSummaryEmail", c => c.Boolean(nullable: false, defaultValue: true));
2 голосов
/ 31 мая 2012

Это мой способ установки важных свойств с помощью private setters в методе создания вместо использования конструктора

Модель

public class User
{
    public static User Create(Action<User> init)
    {
        var user = new User();
        user.Guid = Guid.NewGuid();
        user.Since = DateTime.Now;
        init(user);
        return user;
    }

    public int UserID { get; set; }

    public virtual ICollection<Role> Roles { get; set; }
    public virtual ICollection<Widget> Widgets { get; set; }

    [StringLength(50), Required]
    public string Name { get; set; }
    [EmailAddress, Required]
    public string Email { get; set; }
    [StringLength(255), Required]
    public string Password { get; set; }
    [StringLength(16), Required]
    public string Salt { get; set; }

    public DateTime Since { get; private set; }
    public Guid Guid { get; private set; }
}

Созданиеновый пользователь

context.Users.Add(User.Create(c=>
{
    c.Name = "User";
    c.Email = "some@one.com";
    c.Salt = salt;
    c.Password = "mypass";
    c.Roles = new List<Role> { adminRole, userRole };
}));
2 голосов
/ 28 октября 2010

Не удалось найти способ добавить значение по умолчанию, кроме ручного редактирования через текстовый редактор / приложение Это ошибка в Entity Framework ...

...