Heim > Datenbank > MySQL-Tutorial > Wie implementiert man IN-Unterabfragen effizient in LINQ to SQL?

Wie implementiert man IN-Unterabfragen effizient in LINQ to SQL?

Susan Sarandon
Freigeben: 2024-12-27 12:50:21
Original
272 Leute haben es durchsucht

How to Efficiently Implement IN Subqueries in LINQ to SQL?

Verarbeitung von IN-Unterabfragen in LINQ to SQL

Die Verwendung von IN-Unterabfragen in LINQ to SQL kann eine effiziente Möglichkeit sein, Daten zu korrelieren aus mehreren Tabellen. So gehen Sie vor:

Allgemeine IN-Abfrageimplementierung:

Um eine IN-Abfrage in LINQ to SQL zu implementieren, folgen Sie dieser Syntax:

var q = from t1 in table1
        let t2s = from t2 in table2
                  where <Conditions for table2>
                  select t2.KeyField
        where t2s.Contains(t1.KeyField)
        select t1;
Nach dem Login kopieren

Spezifisches Beispiel:

Lassen Sie uns das Beispiel-SQL noch einmal betrachten Abfrage:

SELECT f.* 
FROM Foo f
WHERE f.FooId IN (
    SELECT fb.FooId
    FROM FooBar fb
    WHERE fb.BarId = 1000
)
Nach dem Login kopieren

In LINQ to SQL würde dies wie folgt übersetzt werden:

var query = from f in db.Foo
            let fubars = from fb in db.FooBar
                          where fb.BarId == 1000
                          select fb.FooId
            where fubars.Contains(f.FooId)
            select f;
Nach dem Login kopieren

Zusätzliche Überlegungen:

Für EXISTS-Abfragen Sie kann die Any()-Methode anstelle von Contains():

var q = from t1 in table1
        let t2s = from t2 in table2
                  where <Conditions for table2>
                  select t2.KeyField
        where t2s.Any(t1.KeyField)
        select t1;
Nach dem Login kopieren
verwenden

Das obige ist der detaillierte Inhalt vonWie implementiert man IN-Unterabfragen effizient in LINQ to SQL?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage