未分類

C#LINQ - 実際に実行される SQL をログ出力する

準備

1. こちらを参考にして、SQL Server 用の NORTHWND.MDF を用意します。
2. NORTHWND.MDF ファイルをソリューションエクスプローラーのプロジェクトノードにドラッグ & ドロップします。
- データセットを選択して、[次へ] をクリックします。
- テーブルにチェックを付けて、[完了] をクリックします。
2. プロジェクトに新しい項目として、LINQ to SQL クラスを追加します。名前を Northwnd.dbml とします。
3. ソリューションエクスプローラーから Northwnd.dbml を開きます。
4. サーバーエクスプローラーからテーブルの employee をNorthwnd.dbml にドラッグ & ドロップします。

デザイン

1. フォーム (Form1) にボタン (button1) を配置します。
2. フォーム (Form1) にリストボックス (listBox1) を配置します。

サンプルコード (C#)

// 名前空間の追加
// (なし)

// コード
private void button1_Click(object sender, EventArgs e)
{
  NorthwndDataContext North = new NorthwndDataContext();
  
  North.Log = Console.Out;
  var query = from emp in North.Employees
              select emp;
  
  foreach (var emp in query)
  {
    ;
  }
}

解説

データコンテキスト (pubs) の log プロパティを設定することで、SQL Server に実際に発行された SQL を出力できます。

ここで面白いのは、SQL の発行は、LINQ を実行したときではなく、foreach によってコレクションにアクセスした時だということです。

結果

動作確認環境

Visual Studio 2015 Professional (C# 6.0)

-未分類