如何使用EntityFramework Code First FluentAPI为bool属性设置默认值?
类似的东西:
Property(l => l.PropertyFlag).HasColumnType("bit").DefaultValue(1);
答案 0 :(得分:29)
好消息,代码首先支持这一点。在生成的迁移的“Up()”方法中,使用以下语法指定默认值:
AddColumn("[table name]", "[column name]", c => c.Boolean(nullable: false, defaultValue: false));
答案 1 :(得分:9)
我不确定流畅的方式,但你只需在无参数构造函数中设置属性......
public class MyTable
{
public MyTable()
{
CanSetDefault = true;
}
public bool CanSetDefault {get; set; }
}
<强>更新强>
快速谷歌建议不可能使用流畅的api ...
http://social.msdn.microsoft.com/Forums/en-US/ad854e28-02f5-451b-9000-c8bcb1355d0b/codefirst-ctp5-and-default-values?forum=adonetefx
答案 2 :(得分:2)
此处的另一个选项是使用您自己的类覆盖默认的 SqlServerMigrationSqlGenerator 类。然后,您可以在Generate方法中注入您想要发生的某些事情(例如,默认值)。与此相关的好处是你也可以在其他应用程序中使用它,因为它非常通用。 Here是一个很好的解释。
internal class CustomSqlServerMigrationSqlGenerator : SqlServerMigrationSqlGenerator
{
protected override void Generate(AddColumnOperation addColumnOperation)
{
SetCreatedUtcColumn(addColumnOperation.Column);
base.Generate(addColumnOperation);
}
protected override void Generate(CreateTableOperation createTableOperation)
{
SetCreatedUtcColumn(createTableOperation.Columns);
base.Generate(createTableOperation);
}
private static void SetCreatedUtcColumn(IEnumerable<ColumnModel> columns)
{
foreach (var columnModel in columns)
{
SetCreatedUtcColumn(columnModel);
}
}
private static void SetCreatedUtcColumn(PropertyModel column)
{
if (column.Name == "CreatedUtc")
{
column.DefaultValueSql = "GETUTCDATE()";
}
}
}
答案 3 :(得分:0)
由于EF没有我需要的功能,例如默认值和唯一键作为外键,我们必须将ORM从EF更改为NHibernate。在我看来,NHibernate比EF 6.X具有更多功能。