首頁 > 資料庫 > mysql教程 > 如何在 LINQ 中處理 NULL 值:相當於 SQL 的 ISNULL?

如何在 LINQ 中處理 NULL 值:相當於 SQL 的 ISNULL?

DDD
發布: 2024-12-30 05:27:10
原創
276 人瀏覽過

How to Handle NULL Values in LINQ: The Equivalent of SQL's ISNULL?

SQL 的 ISNULL 的 LINQ 等效項

在 SQL 中,ISNULL 函數允許以預設值取代空值。本文示範如何使用 LINQ 實現類似的結果。

具有可為空列的LINQ 查詢

考慮以下LINQ 查詢:

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
        };
登入後複製

在此查詢中,aa 表示HandheldDevInfos 中對於給定資產可能存在也可能不存在的行。此外,xx.Online 欄位是不可為 null 的位元類型。

將 Null 值設為 False

要將 xx.Online 的 null 值設為 false,我們可以使用空白合併運算子 (??)。更新後的查詢如下所示:

select new {
    AssetID = x.AssetID,
    Status = aa == null ? false : aa.Online;
}
登入後複製

在此修訂後的查詢中,如果 aa 為 null,則 Status 屬性將設為 false。否則,它將被設定為 aa.Online 的值。

範例和等效T-SQL

要在更大的上下文中說明此方法,請考慮以下內容Northwind 範例查詢:

        using(var ctx = new DataClasses1DataContext())
        {
            ctx.Log = Console.Out;
            var qry = from boss in ctx.Employees
                      join grunt in ctx.Employees
                          on boss.EmployeeID equals grunt.ReportsTo into tree
                      from tmp in tree.DefaultIfEmpty()
                      select new
                             {
                                 ID = boss.EmployeeID,
                                 Name = tmp == null ? "" : tmp.FirstName
                        };
            foreach(var row in qry)
            {
                Console.WriteLine("{0}: {1}", row.ID, row.Name);
            }
        }
登入後複製

顯示了使用類似方法的等效T-SQL查詢如下:

SELECT [t0].[EmployeeID] AS [ID],
    (CASE
        WHEN [t2].[test] IS NULL THEN CONVERT(NVarChar(10),@p0)
        ELSE [t2].[FirstName]
     END) AS [Name]
FROM [dbo].[Employees] AS [t0]
LEFT OUTER JOIN (
    SELECT 1 AS [test], [t1].[FirstName], [t1].[ReportsTo]
    FROM [dbo].[Employees] AS [t1]
    ) AS [t2] ON ([t0].[EmployeeID]) = [t2].[ReportsTo]
登入後複製

透過利用空合併運算符,LINQ 查詢可以優雅地處理空值,提供一種方便的方法來替換預設值或根據資料存在或不存在執行其他操作。

以上是如何在 LINQ 中處理 NULL 值:相當於 SQL 的 ISNULL?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板