我一直在使用 Entity Framework CTP4 研究 Code First,您可以使用 ModelBuilder 来构建表格列。有没有办法使用 ModelBuilder 或其他机制为数据库中的列设置默认值?
谢谢你!
我一直在使用 Entity Framework CTP4 研究 Code First,您可以使用 ModelBuilder 来构建表格列。有没有办法使用 ModelBuilder 或其他机制为数据库中的列设置默认值?
谢谢你!
我正在使用构造函数来设置默认值。从来没有让我失望
public class Activity
{
[Required]
public DateTime AddedDate { get; set; }
public Activity()
{
AddedDate = DateTime.Now;
}
}
在为迁移生成的代码中,您可以为列指定默认值:
AddColumn("users", "ReceiveSummaryEmail", c => c.Boolean(nullable: false, defaultValue: true));
除了通过文本编辑器/应用程序手动编辑之外,找不到添加默认值的方法这是实体框架中的错误...
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 };
}));