ホームページ > データベース > mysql チュートリアル > LINQ で NULL 値を処理する方法: SQL の ISNULL に相当しますか?

LINQ で NULL 値を処理する方法: SQL の ISNULL に相当しますか?

DDD
リリース: 2024-12-30 05:27:10
オリジナル
297 人が閲覧しました

How to Handle NULL Values in LINQ: The Equivalent of SQL's ISNULL?

LINQ SQL の ISNULL と同等

SQL では、ISNULL 関数を使用して、null 値の代わりにデフォルト値を置き換えることができます。この記事では、LINQ を使用して同様の結果を達成する方法を示します。

Null 許容列を使用した LINQ クエリ

次の 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
        };
ログイン後にコピー

このクエリでは、aa は、特定のオブジェクトに対して存在する場合も存在しない場合もある HandheldDevInfos の行を表します。 資産。さらに、xx.Online 列は null 非許容ビット型です。

Null 値を False に設定する

xx.Online の Null 値を false に設定するには、次のようにします。 null 合体演算子 (??) を使用できます。更新されたクエリは次のようになります。

select new {
    AssetID = x.AssetID,
    Status = aa == null ? false : aa.Online;
}
ログイン後にコピー

この改訂されたクエリでは、aa が null の場合、Status プロパティは false に設定されます。それ以外の場合は、aa.Online.

例と同等の T-SQL

このアプローチをより大きなコンテキストで説明するには、次のことを考慮してください。 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);
            }
        }
ログイン後にコピー

同様のアプローチを使用する同等の T-SQL クエリを示します。以下:

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]
ログイン後にコピー

null 合体演算子を利用することで、LINQ クエリは null 値をエレガントに処理でき、データの有無に基づいて既定値を置き換えたり、他の操作を実行したりする便利な方法を提供します。

以上がLINQ で NULL 値を処理する方法: SQL の ISNULL に相当しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート