Можно ли сопоставить столбец таблицы с полем класса вместо свойства класса и как?
ВЫ МОЖЕТЕ СДЕЛАТЬ ЭТО:)
Перейдите по этой ссылке: http://weblogs.asp.net/ricardoperes/archive/2013/08/22/mapping-non-public-members-with-entity-framework-code-first.aspx
Это распространенный запрос, и он действительно имеет смысл; нам нужно использовать выражения LINQ и немного магии отражения. Во-первых, вспомогательная функция для возврата выражения, указывающего на член:
public static class ExpressionHelper
{
public static Expression<Func<TEntity, TResult>> GetMember<TEntity, TResult>(String memberName)
{
ParameterExpression parameter = Expression.Parameter(typeof(TEntity), "p");
MemberExpression member = Expression.MakeMemberAccess(parameter, typeof(TEntity).GetMember(memberName, BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance).Single());
Expression<Func<TEntity, TResult>> expression = Expression.Lambda<Func<TEntity, TResult>>(member, parameter);
return (expression);
}
}
Затем мы вызываем его в методе DbContext.OnModelCreating в качестве параметра для StructuralTypeConfiguration.Property:
.
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Project>().Property(ExpressionHelper.GetMember<Project, Decimal>("Budget")).IsRequired();
base.OnModelCreating(modelBuilder);
}