Rumah >pembangunan bahagian belakang >C++ >Bagaimana dengan Cekap Menukar Entiti Anak Bukan Kutipan kepada DTO dalam Teras Rangka Kerja Entiti?
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.
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:
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>
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>
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!