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

しかし、null 不可 (xx.online) のビット型を持つ列がありますが、null の場合、これを false に設定するにはどうすればよいですか?

4

4 に答える 4

59

aanullの可能性があるセット/オブジェクトなので、確認できますかaa == null?

( aa/xx交換可能かもしれません (質問のタイプミス); 元の質問は について話しますxxが、定義するだけですaa)

すなわち

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 ファイルの必須フィールド ( ) にプロパティを設定する必要ありますNullabletruexx.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

(離散値ではなく) シーケンスでこの問題がよく発生します。int のシーケンスがあり、それらを合計したい場合、リストが空の場合、「InvalidOperationException: The null value cannot be assigned to a member with type System.Int32 which is a non-nullable valueタイプ。"。

シーケンスをnull許容型にキャストすることでこれを解決できることがわかりました。Null 許容型のシーケンスが空の場合、SUM およびその他の集計演算子はこのエラーをスローしません。

たとえば、このようなもの

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

になる

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

2 つ目は、where 句に一致する行がない場合に 0 を返します。(最初のものは、一致する行がない場合に例外をスローします)。

于 2010-08-28T17:27:28.800 に答える
0

タイプはブール値のように見えるため、null にすることはできず、デフォルトで false にする必要があります。

于 2009-01-05T13:41:32.170 に答える