Heim >Backend-Entwicklung >C++ >Wie verbinde ich mehrere Tabellen in LINQ mithilfe von Lambda-Ausdrücken?

Wie verbinde ich mehrere Tabellen in LINQ mithilfe von Lambda-Ausdrücken?

Susan Sarandon
Susan SarandonOriginal
2025-01-10 10:58:42284Durchsuche

How to Join Multiple Tables in LINQ Using Lambda Expressions?

Mehrere Tabellen mit LINQ Lambda-Ausdrücken verknüpfen

Wenn Sie in LINQ mit mehreren Tabellen arbeiten, müssen Sie diese möglicherweise zusammenführen, um verwandte Daten zu sammeln. Dies kann durch Lambda-Ausdrücke in LINQ erreicht werden.

Gehen Sie von folgendem Szenario aus:

  • Sie haben Klassen für Produkt, Kategorie und Produktkategorie (zugehörige Tabelle).
  • Sie möchten alle drei Tabellen verknüpfen und ein anderes Objekt (CategorizedProducts) mit bestimmten Eigenschaften füllen.

Das Folgende ist eine aktualisierte Version des Codes, der Lambda-Ausdrücke verwendet, um die Verknüpfung durchzuführen:

<code class="language-csharp">var categorizedProducts = product
    .Join(productcategory, p => p.Id, pc => pc.ProdId, (p, pc) => new { p, pc })
    .Join(category, ppc => ppc.pc.CatId, c => c.Id, (ppc, c) => new { ppc, c })
    .Select(m => new CategorizedProducts
    {
        ProdId = m.ppc.p.Id, // 或 m.ppc.pc.ProdId
        CatId = m.c.CatId,
        // 其他赋值
    });</code>

In diesem Code:

  • Der Join-Vorgang verbindet Tabellen basierend auf angegebenen Bedingungen.
  • Anonyme Typen dienen als Zwischendarstellungen für verkettete Daten.
  • Auswahlvorgang projiziert die erforderlichen Eigenschaften in das CategorizedProducts-Objekt.

Diese Lösung stellt eine einzelne Klasse bereit, die alle Eigenschaften in der Join-Tabelle enthält, sodass Sie das CategorizedProducts-Objekt nach Bedarf füllen können.

Das obige ist der detaillierte Inhalt vonWie verbinde ich mehrere Tabellen in LINQ mithilfe von Lambda-Ausdrücken?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn