Heim > Datenbank > MySQL-Tutorial > Wie gehe ich mit Nullable-Werten in LINQ-Abfragen wie ISNULL von SQL um?

Wie gehe ich mit Nullable-Werten in LINQ-Abfragen wie ISNULL von SQL um?

Mary-Kate Olsen
Freigeben: 2024-12-29 20:55:10
Original
963 Leute haben es durchsucht

How to Handle Nullable Values in LINQ Queries Like SQL's ISNULL?

Nullable-Werte in LINQ-Abfragen

In SQL ermöglicht die ISNULL-Funktion das Ersetzen einer leeren Zeichenfolge durch Nullwerte. Bei der Übersetzung dieser Funktionalität in LINQ-Abfragen kann ein ähnlicher Ansatz gewählt werden.

Betrachten Sie diese LINQ-Abfrage, die einen Join mit einer Nullable-Bit-Spalte namens xx.Online enthält:

var hht = from x in db.HandheldAssets
        join a in db.HandheldDevInfos on x.AssetID equals a.DevName into DevInfo
        from aa in DevInfo.DefaultIfEmpty()
        select new
        {
        AssetID = x.AssetID,
        Status = xx.Online
        };
Nach dem Login kopieren

Zum Konto Für potenzielle Nullwerte in aa.Online kann ein nullbedingter Operator verwendet werden:

select new {
    AssetID = x.AssetID,
    Status = aa == null ? (bool?)null : aa.Online; // a Nullable<bool>
}
Nach dem Login kopieren

Diese Prüfung stellt sicher, dass aa vorher nicht null ist Zugriff auf seine Online-Eigenschaft. Wenn aa null ist, ist das Ergebnis ein boolescher Nullwert.

Eine andere Option besteht darin, Nullwerten einen Standardwert (z. B. false) zuzuweisen:

select new {
    AssetID = x.AssetID,
    Status = aa == null ? false : aa.Online;
}
Nach dem Login kopieren

In diesem Szenario Nullwerte werden durch den angegebenen Standardwert ersetzt.

Durch die Verwendung dieser Techniken ist es möglich, Nullwerte in LINQ-Abfragen ähnlich zu behandeln, wie ISNULL verwendet wird in SQL.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Nullable-Werten in LINQ-Abfragen wie ISNULL von SQL um?. 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