LINQ中SQL ISNULL的等价物

在SQL中,你可以运行一个ISNULL(null,'')你如何在linq查询中做到这一点?

我有一个join这个查询:

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

但我有一个不能为空的位types(xx.online)如何设置为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属性设置为true

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

我经常遇到序列问题(与离散值相反)。 如果我有一个整数序列,我想SUM他们,当列表为空时,我会收到错误“InvalidOperationException:空值不能分配给typesSystem.Int32这是一个非空值的成员types。”。

我发现我可以通过将序列转换为可空types来解决这个问题。 如果一个可为空的types为空,则SUM和其他聚合运算符不会抛出此错误。

所以例如这样的事情

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

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

当没有行匹配where子句时,第二个将返回0。 (当没有行匹配时,第一个引发exception)。

看起来这个types是布尔型的,因此不能为null,默认情况下应该是false。