Rumah >pembangunan bahagian belakang >C++ >Bagaimana dengan Cekap Menukar Entiti Anak Bukan Kutipan kepada DTO dalam Teras Rangka Kerja Entiti?

Bagaimana dengan Cekap Menukar Entiti Anak Bukan Kutipan kepada DTO dalam Teras Rangka Kerja Entiti?

Mary-Kate Olsen
Mary-Kate Olsenasal
2025-01-23 19:57:13822semak imbas

Memetakan Entiti Kanak-Kanak Bukan Kutipan dengan cekap kepada DTO dalam Teras Rangka Kerja Entiti

Teras Rangka Kerja Entiti memudahkan penukaran entiti-ke-DTO (Objek Pemindahan Data) menggunakan pepohon ungkapan. Ini berfungsi dengan baik untuk objek induk dan koleksi anak, tetapi pengendalian sifat anak bukan koleksi memerlukan pendekatan yang berbeza.

How to Efficiently Convert Non-Collection Child Entities to DTOs in Entity Framework Core?

Cabaran:

Pertimbangkan model ini:

<code class="language-csharp">public class Model
{
    public int ModelId { get; set; }
    public string ModelName { get; set; }
    public virtual ICollection<ChildModel> ChildModels { get; set; }
    public AnotherChildModel AnotherChildModel { get; set; }
}</code>

Pemetaan terus ke DTO menggunakan ungkapan mudah seperti ini gagal untuk AnotherChildModel:

<code class="language-csharp">public static Expression<Func<Model, ModelDto>> AsDto =>
    model => new ModelDto
    {
        ModelId = model.ModelId,
        ModelName = model.ModelName,
        ChildModels = model.ChildModels.AsQueryable().Select(ChildModel.AsDto).ToList()
        // AnotherChildModel mapping missing
    };</code>

Penyelesaian: Memanfaatkan Perpustakaan Luar

Beberapa perpustakaan memperluaskan keupayaan pokok ekspresi untuk mengendalikan senario ini:

  • LINQKit: Menggunakan atribut Expandable untuk menandakan kaedah pengembangan oleh pembekal pertanyaan.
<code class="language-csharp">[Expandable(nameof(AsDtoImpl))]
public static ModelDto AsDto(Model model) => AsDtoImpl.Compile()(model);

private static readonly 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>

Gunakan .AsExpandable() dalam pertanyaan anda:

<code class="language-csharp">dbContext.Models
    .Where(m => SomeCriteria)
    .Select(Model.AsDto)
    .AsExpandable()
    .ToList();</code>
  • NeinLinq: Serupa dengan LINQKit, menggunakan atribut InjectLambda.
<code class="language-csharp">[InjectLambda]
public static ModelDto AsDto(Model model) { /* ... same implementation as LINQKit ... */ }</code>

Gunakan .ToInjectable() dalam pertanyaan anda:

<code class="language-csharp">dbContext.Models
    .Where(m => SomeCriteria)
    .Select(Model.AsDto)
    .ToInjectable()
    .ToList();</code>
  • DelegateDecompiler: Menawarkan sintaks yang lebih mudah dengan atribut Computed.
<code class="language-csharp">[Computed]
public static ModelDto AsDto(Model model) { /* ... same implementation as LINQKit ... */ }</code>

Gunakan .Decompile() dalam pertanyaan anda:

<code class="language-csharp">dbContext.Models
    .Where(m => SomeCriteria)
    .Select(Model.AsDto)
    .Decompile()
    .ToList();</code>

Perpustakaan ini menyediakan penyelesaian yang cekap untuk memetakan entiti anak bukan koleksi kepada DTO dalam pertanyaan Teras Rangka Kerja Entiti, mengelakkan pengehadan pemetaan pokok ungkapan asas. Pilih perpustakaan yang paling sesuai dengan keperluan projek anda dan gaya pengekodan.

Atas ialah kandungan terperinci Bagaimana dengan Cekap Menukar Entiti Anak Bukan Kutipan kepada DTO dalam Teras Rangka Kerja Entiti?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn