簡體   English   中英

LINQ中SQL ISNULL的等價物?

[英]Equivalent of SQL ISNULL in LINQ?

在SQL中你可以運行一個ISNULL(null,'')你如何在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
        };

但是我有一個不可為空的位類型的列(xx.online)如果它為null,如何將其設置為false?

由於aa是可能為null的set / object,你可以檢查aa == null嗎?

aa / xx可能是可以互換的(問題中的拼寫錯誤);原始問題是關於xx但只定義aa

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

或者如果您希望默認值為false (非null ):

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

更新; 為了回應downvote,我調查了更多...事實是,這是正確的方法! 這是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);
            }
        }

這里是TSQL - 幾乎是我們想要的(它不是ISNULL ,但它足夠接近):

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]
-- @p0: Input NVarChar (Size = 0; Prec = 0; Scale = 0) []
-- Context: SqlProvider(Sql2008) Model: AttributedMetaModel Build: 3.5.30729.1

QED?

你可以用?? 運算符設置默認值但首先必須在dbml文件中的必需字段xx.Online Nullable屬性設置為truexx.Online

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

我經常遇到序列問題(與離散值相反)。 如果我有一個int序列,並且我想要求它們,當列表為空時,我將收到錯誤“InvalidOperationException:無法將null值賦給類型為System.Int32的成員,這是一個不可為空的值類型。”。

我發現我可以通過將序列轉換為可空類型來解決這個問題。 如果一系列可空類型為空,則SUM和其他聚合運算符不會拋出此錯誤。

例如,像這樣的東西

MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => x.AnIntegerValue);

MySum = MyTable.Where(x => x.SomeCondtion).Sum(x => (int?) x.AnIntegerValue);

當沒有行匹配where子句時,第二個將返回0。 (第一個在沒有行匹配時拋出異常)。

看起來類型是布爾值,因此永遠不能為null,默認情況下應該為false。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM