Entity Framework Code First CTP4 默认列值是什么?

12

我一直在研究使用实体框架 CTP4 的 Code First,可以使用 ModelBuilder 构建表列。是否有一种方法可以使用 ModelBuilder 或其他机制为数据库中的列设置默认值?

谢谢!


4个回答

38

我正在使用构造函数来设置默认值。从未让我失望过。

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

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

1
唯一的问题是数据库默认值更有效率。 - Sleeper Smith
4
除了它实际上没有回答问题,它提供了一个解决方法,但这不是被问到的,因此正确的答案(对于所提出的问题)是它不受支持,因此接受另一个方案。 - Murph
2
嗯,我再重复一遍,你并没有解决问题,也没有回答这个问题 - 这只是一个解决方式,是一种有效的方法,肯定很有用(这就是为什么得到了赞同),但这并不意味着它就是“正确”的答案。赞同将允许其他用户评估它是否对他们解决了问题(尽管对我的用例来说并没有)。 - Murph
1
@Murph 显然有21个人认为这是正确答案。我正在考虑开一个新问题,在那里发布我的答案并从这里删除此答案。 - Korayem
1
这在使用EF6和一个完全空白(从头开始)的数据库时完美运行。 - FoggyDay
显示剩余6条评论

4
在生成迁移代码时,您可以为列指定默认值:
AddColumn("users", "ReceiveSummaryEmail", c => c.Boolean(nullable: false, defaultValue: true));

2
这是我的方法,在创建方法中使用私有设置器设置重要属性,而不是通过构造函数设置。 模型
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

除了手动通过文本编辑器/应用程序进行编辑,找不到添加默认值的方法,这是Entity Framework中的一个错误...


有没有一种方法可以设置默认值,但它不起作用,是个错误吗?还是当前版本完全缺少该功能? - Lukasz
1
一个缺失的功能不应被认为是一个漏洞。 - Trevi Awater

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接