首页 > 后端开发 > C++ > 我们如何在 EF Core 中高效地将实体转换为 DTO,包括单实体子属性?

我们如何在 EF Core 中高效地将实体转换为 DTO,包括单实体子属性?

Patricia Arquette
发布: 2025-01-23 19:52:26
原创
686 人浏览过

How Can We Efficiently Convert Entities to DTOs in EF Core, Including Single-Entity Child Properties?

在EF Core中使用可复用代码进行自定义DTO转换:单个实体子属性

问题陈述:

使用实体框架核心查询数据时,如何扩展实体到DTO对象的转换以包含非集合子属性?

实现:

在EF Core中,表达式用于将实体转换为DTO,这对于主实体及其子集合非常有效。但是,将此方法应用于非集合子属性已被证明具有挑战性。

解决方案:

为了解决这个问题,我们可以利用LINQKit、NeinLinq或DelegateDecompiler等库。这些库允许我们定义一个包含主实体和附加子属性的转换函数。

示例:

使用LINQKit:

<code class="language-csharp">[Expandable(nameof(AsDtoImpl))]
public static ModelDto AsDto(Model model)
{
   _asDtoImpl ??= AsDtoImpl().Compile();
   return _asDtoImpl(model);
}

private static Func<Model, ModelDto> _asDtoImpl;

private static Expression<Func<Model, ModelDto>> AsDtoImpl =>
    model => new ModelDto
    { 
        ModelId = model.ModelId,
        ModelName = model.ModelName,
        ChildModels = model.ChildModels.AsQueryable().Select(ChildModel.AsDto).ToList(),
        AnotherChildModel = new AnotherChildModelDto
        {
            AnotherChildModelId = model.AnotherChildModel.AnotherChildModelId //修正此处
        }
    };</code>
登录后复制

使用库的AsExpandable()函数,可以在执行之前扩展查询:

<code class="language-csharp">dbContext.Models
   .Where(m => SomeCriteria)
   .Select(m => Model.AsDto(m))
   .AsExpandable()
   .ToList();</code>
登录后复制

对于LINQKit,可以通过在DbContext配置中全局启用表达式扩展来简化此过程。NeinLinq和DelegateDecompiler等其他库提供了类似的方法。 请注意,示例代码中AnotherChildModel 属性的访问方式进行了修改,以更准确地反映从model.AnotherChildModel 获取AnotherChildModelId 的过程。 这假设AnotherChildModel 是一个对象,而不是一个单独的ID。

以上是我们如何在 EF Core 中高效地将实体转换为 DTO,包括单实体子属性?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板