51

在 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),如果它为空,如何将其设置为假?

4

4 回答 4

59

既然aa集合/对象可能为空,你能检查一下aa == null吗?

aa/xx可能可以互换(问题中的拼写错误);原始问题谈论xx但仅定义aa

IE

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

或者,如果您希望默认为false(not null):

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

更新; 为了回应反对票,我进行了更多调查……事实是,这是正确的方法!以下是关于 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?

于 2009-01-05T14:34:59.927 回答
27

您可以使用??操作符设置默认值,但首先您必须在dbml文件中的必填字段 ( )中将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
        };
于 2009-01-05T14:21:44.023 回答
2

我经常遇到序列问题(与离散值相反)。如果我有一个整数序列,并且我想对它们求和,当列表为空时,我将收到错误“InvalidOperationException:无法将空值分配给类型为 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。(当没有行匹配时,第一个抛出异常)。

于 2010-08-28T17:27:28.800 回答
0

看起来类型是布尔值,因此永远不能为空,默认情况下应该为假。

于 2009-01-05T13:41:32.170 回答