Heim >Backend-Entwicklung >C++ >Wie kann ich ein WHERE IN-Klauseläquivalent in LINQ effizient verwenden?

Wie kann ich ein WHERE IN-Klauseläquivalent in LINQ effizient verwenden?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-06 16:49:44736Durchsuche

How Can I Efficiently Use a WHERE IN Clause Equivalent in LINQ?

Where IN-Klausel in LINQ (verbesserte Lösung)

In SQL wird die WHERE IN-Klausel verwendet, um zu überprüfen, ob ein Feld mit einem Wert übereinstimmt aus einer Liste. Mit dem folgenden verbesserten Ansatz können Sie eine ähnliche Funktionalität in LINQ erreichen.

public List<State> Wherein(string listofcountrycodes)
{
    string[] countryCode = listofcountrycodes.Split(',');
    var states = from states in _objdatasources.StateList()
                 where countryCode.Contains(states.CountryCode)
                 select new State
                 {
                     StateName = states.StateName
                 };
    return states.ToList();
}

Dieser Code verwendet die LINQ-Contains-Methode, um zu überprüfen, ob der CountryCode eines Staates mit einem Wert im CountryCode-Array übereinstimmt. Die ToList-Methode wird verwendet, um die Statusabfrage in eine konkrete Liste umzuwandeln.

Erklärung:

  • Die from-Klausel definiert den Bereich der abzufragenden Elemente in In diesem Fall die StateList des _objdatasources-Objekts.
  • Die where-Klausel filtert die Ergebnisse basierend auf der Bedingung CountryCode.Contains(states.CountryCode), der prüft, ob der CountryCode des aktuellen Bundesstaates in der Liste der Ländercodes vorhanden ist.
  • Die Select-Klausel projiziert die ausgewählten Bundesstaaten in eine neue Liste von State-Objekten, die nur enthält die StateName-Eigenschaft.
  • Schließlich konvertiert die ToList-Methode die LINQ-Abfrage in eine konkrete List Objekt.

Das obige ist der detaillierte Inhalt vonWie kann ich ein WHERE IN-Klauseläquivalent in LINQ effizient verwenden?. 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