有一些类似这样的代码。
appScript.AppScriptDetails = Ent.AppScriptDetails.Where(c => c.AppScriptID == appScript.ID).OrderBy(c => c.SortOrder);我想要加载对象,除了一个字符串属性。我有什么选择?
发布于 2014-11-04 03:22:44
投影相同类型的新实体,但忽略不需要的属性,或为不需要的属性提供默认值:
appScript.AppScriptDetails = Ent.AppScriptDetails
.Where(c => c.AppScriptID == appScript.ID)
.OrderBy(c => c.SortOrder)
.Select(c => new AppScriptDetail
{
AppScriptID = c.AppScriptID,
// Same for other wanted properties
UnwantedStringProperty = null // Provide a default value
});或者,如果只需要在本地使用数据,则可以投影匿名类型并完全忽略不需要的属性。
发布于 2014-11-04 03:37:30
在我看来,你有两种可能性:
1.手动映射所需的属性
appScript.AppScriptDetails = Ent.AppScriptDetails
.Where(c => c.AppScriptID == appScript.ID)
.OrderBy(c => c.SortOrder)
.Select(c => new
{
prop => prop,
prop2 => prop2
}).ToList();基本上,您映射所有属性,除了您希望忽略的属性。
2.使用AutoMapper IQueryableExtensions
类似于:
Mapper.CreateMap<AppScriptDetails, AppScriptDetailsModel>()
.ForMember(m => m.IgnoredProp,
opt => opt.Ignore());
appScript.AppScriptDetails = Ent.AppScriptDetails
.Where(c => c.AppScriptID == appScript.ID)
.OrderBy(c => c.SortOrder)
.Project().To<AppScriptDetailsModel>().ToList();https://stackoverflow.com/questions/26721395
复制相似问题