entity framework代码优先 – 如何在保存时忽略列
我有一个名为Client的类,它首先使用Entity Framework代码映射到数据库表。 该表有一个我需要在Client类中提供的计算字段,但我知道不可能写入该字段。 是否有一种方法可以在保存时配置entity framework以忽略该属性,但在读取时包含该属性?
我已尝试在配置类中使用Ignore方法,或使用[NotMapped]属性,但这些会阻止从数据库中读取属性。
您可以将DatabaseGeneratedAttribute
与DatabaseGeneratedOption.Computed
选项一起使用:
[DatabaseGenerated(DatabaseGeneratedOption.Computed)] public ComputedPropertyType ComputedProperty { get; set; }
或者如果您更喜欢流畅的api,您可以在DbContext
类中使用HasDatabaseGeneratedOption
方法:
public class EntitiesContext : DbContext { public DbSet Enities { get; set; } protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity ().Property(e => e.ComputedProperty).HasDatabaseGeneratedOption(DatabaseGeneratedOption.Computed); } }
将属性标记为已计算:
modelBuilder .Entity() .Property(_ => _.MyProperty) .HasDatabaseGeneratedOption(DatabaseGeneratedOption.Computed);