[英]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
属性设置为true
( xx.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.