Heim > Datenbank > MySQL-Tutorial > Warum löst LINQ to SQL beim Verknüpfen mit lokalen Sammlungen den Fehler „Lokale Sequenznutzungsbeschränkung' aus?

Warum löst LINQ to SQL beim Verknüpfen mit lokalen Sammlungen den Fehler „Lokale Sequenznutzungsbeschränkung' aus?

Linda Hamilton
Freigeben: 2024-12-27 21:36:15
Original
584 Leute haben es durchsucht

Why Does LINQ to SQL Throw a

LINQ to SQL-Fehler: Einschränkung der Verwendung lokaler Sequenzen

In LINQ to SQL können Abfrageoperatoren keine lokalen Sequenzen verwenden, mit Ausnahme von Contains() Operator. Dieser Fehler tritt häufig auf, wenn versucht wird, Verknüpfungen zwischen SQL-Quellen und lokalen Quellen durchzuführen.

Das bereitgestellte Codefragment zeigt eine Verknüpfung zwischen der Shop.Sections-Tabelle und einer lokalen Sammlung, obj.SectionObjects. Dieser Vorgang ist jedoch ungültig, was zu folgendem Fehler führt: „Die lokale Sequenz kann in der LINQ to SQL-Implementierung von Abfrageoperatoren außer dem Operator „Contains()“ nicht verwendet werden.“

Lösung: Datenabruf vor dem Join

Um diesen Fehler zu beheben, rufen Sie die SQL-Daten in den Speicher ab, bevor Sie den Join versuchen. In diesem Szenario führen wir keinen echten Join durch, sondern eine „select...where...selectid in“-Abfrage. Dies kann mit der Methode „Contains()“ erreicht werden:

var SE = Shop.Sections
            .Where(s => obj.SectionObjects
                           .Select(so => so.SectionId)
                           .Contains(s.SectionId))
            .ToList();
Nach dem Login kopieren

Diese Abfrage wird wie folgt übersetzt:

select * from Sections where sectionId in (...)
Nach dem Login kopieren

wobei die Liste der IDs in der In-Klausel aus der lokalen Objektsammlung abgeleitet wird . Dieser Ansatz stellt sicher, dass alle in der Abfrage verwendeten Daten Teil der SQL-Quelle sind, wodurch der Fehler behoben wird.

Das obige ist der detaillierte Inhalt vonWarum löst LINQ to SQL beim Verknüpfen mit lokalen Sammlungen den Fehler „Lokale Sequenznutzungsbeschränkung' aus?. 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