实体框架代码第一个CTP4默认列值?

时间:2010-10-27 19:04:15

标签: c# entity-framework-4 entity ctp4

我一直在寻找使用Entity Framework CTP4的Code First,您可以使用ModelBuilder来构建表列。有没有办法使用ModelBuilder或其他一些机制为数据库中的列设置默认值?

谢谢!

4 个答案:

答案 0 :(得分:36)

我正在使用构造函数来设置默认值。永远不会让我失望

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

    public Activity()
    {
        AddedDate = DateTime.Now;
    }
}

答案 1 :(得分:4)

在为迁移生成的代码中,您可以为列指定默认值:

AddColumn("users", "ReceiveSummaryEmail", c => c.Boolean(nullable: false, defaultValue: true));

答案 2 :(得分:2)

除了通过文本编辑器/应用程序手动编辑外,无法找到添加默认值的方法 这是实体框架中的一个错误......

答案 3 :(得分:2)

这是我的方法,在创建方法中使用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 };
}));