有一些像这样的代码。
appScript.AppScriptDetails = Ent.AppScriptDetails.Where(c => c.AppScriptID == appScript.ID).OrderBy(c => c.SortOrder);
我想加载对象,但一个字符串属性除外。我有什么选择?
答案 0 :(得分:1)
投射相同类型的新实体,但省略您不想要的属性,或为不需要的属性提供默认值:
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
});
或者,如果您只需要在本地使用数据,则可以投影匿名类型并完全省略不需要的属性。
答案 1 :(得分:1)
在我看来,你有两种可能性:
<强> 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();