首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Entity-Framework加载对象的一部分?

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

Stack Overflow用户
提问于 2014-11-04 03:18:28
回答 2查看 56关注 0票数 0

有一些类似这样的代码。

代码语言:javascript
复制
appScript.AppScriptDetails = Ent.AppScriptDetails.Where(c => c.AppScriptID == appScript.ID).OrderBy(c => c.SortOrder);

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

EN

回答 2

Stack Overflow用户

发布于 2014-11-04 03:22:44

投影相同类型的新实体,但忽略不需要的属性,或为不需要的属性提供默认值:

代码语言:javascript
复制
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
EN

Stack Overflow用户

发布于 2014-11-04 03:37:30

在我看来,你有两种可能性:

1.手动映射所需的属性

代码语言:javascript
复制
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

类似于:

代码语言:javascript
复制
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();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26721395

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档