


Was ist der Unterschied zwischen den Join- und GroupJoin-Methoden von LINQ?
Vergleich von Join und GroupJoin in LINQ to Entities
GroupJoin verstehen
GroupJoin ist wie Join eine LINQ-Methode zum Kombinieren mehrerer Datenquellen. Allerdings erzeugt GroupJoin Ergebnisse mit einer anderen Struktur als Join.
Beitreten:
- Führen Sie einen Inner Join durch und generieren Sie nur Zeilen, in denen es Übereinstimmungen in beiden verbundenen Tabellen gibt.
- Ergebnis: Eine zusammengeführte Tabelle, die Spalten aus beiden Tabellen enthält.
Gruppenbeitritt:
- Führen Sie einen Outer-Join durch, um Zeilen in der ersten Tabelle mit Zeilen in der zweiten Tabelle abzugleichen.
- Ergebnis: Eine Sammlung von Gruppen, wobei jede Gruppe eine Zeile aus der ersten Tabelle und die entsprechende Zeile aus der zweiten Tabelle enthält (oder eine leere Liste, wenn keine Übereinstimmung vorhanden ist).
Grammatik
Abfragesyntax:
Beitreten:
<code>from p in Parent join c in Child on p.Id equals c.Id select new { p.Value, c.ChildValue }</code>
Gruppenbeitritt:
<code>from p in Parent join c in Child on p.Id equals c.Id into g select new { Parent = p, Children = g }</code>
Methodensyntax (seltener verwendet):
Beitreten:
<code>Parent.Join(Child, p => p.Id, c => c.Id, (p, c) => new { p.Value, c.ChildValue })</code>
Gruppenbeitritt:
<code>Parent.GroupJoin(Child, p => p.Id, c => c.Id, (p, c) => new { Parent = p, Children = c })</code>
Anwendungsfälle
1. Flache Außenverbindung erzeugen:
- GroupJoin kann verwendet werden, um einen abgeflachten äußeren Join zu erstellen, der jede Zeile in der ersten Tabelle enthält, auch wenn es in der zweiten Tabelle keine passenden Zeilen gibt. Dies wird durch eine Abflachung der Gruppe erreicht:
<code>from p in Parent join c in Child on p.Id equals c.Id into g from c in g.DefaultIfEmpty() select new { Parent = p.Value, Child = c?.ChildValue }</code>
2. Ordnung halten:
- Join kann zum Filtern einer Liste unter Beibehaltung der Reihenfolge der Elemente verwendet werden. Durch die Verwendung einer externen Sequenz als erste Liste können Sie die Reihenfolge der Elemente aus der zweiten Liste beibehalten:
<code>from id in ids join p in parents on id equals p.Id select p</code>
Das obige ist der detaillierte Inhalt vonWas ist der Unterschied zwischen den Join- und GroupJoin-Methoden von LINQ?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Welche Werte sind von C -Sprachfunktionen zurückgegeben? Was bestimmt den Rückgabewert?

GULC: C -Bibliothek von Grund auf neu gebaut

C Sprachfunktionsformat -Buchstaben -Fall -Konvertierungsschritte

Was sind die Definitionen und Aufrufregeln von C -Sprachfunktionen und was sind die?

Wo ist der Rückgabewert der C -Sprachfunktion im Speicher?

eindeutiger Gebrauch und Phrasenfreigabe

Wie benutze ich Algorithmen aus der STL (sortieren, finden, transformieren usw.) effizient?

Wie funktioniert die C -Standard -Vorlagenbibliothek (STL)?
