Entity-Framework加载对象的一部分?

时间:2014-11-03 19:18:28

标签: entity-framework

有一些像这样的代码。

appScript.AppScriptDetails = Ent.AppScriptDetails.Where(c => c.AppScriptID == appScript.ID).OrderBy(c => c.SortOrder);

我想加载对象,但一个字符串属性除外。我有什么选择?

2 个答案:

答案 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();