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
Mary-Kate OlsenOriginal
2024-12-29 20:55:10965Durchsuche

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
        };

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>
}

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;
}

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!

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