Entity-framework-command-logging

提供:Dev Guides
移動先:案内検索

Entity Framework-コマンドロギング

Entity Framework 6.0では、 Logging SQL と呼ばれる新しい機能が導入されています。 Entity Frameworkでの作業中に、コマンドまたは同等のSQLクエリをデータベースに送信して、CRUD(作成、読み取り、更新、および削除)操作を実行します。

  • Entity Frameworkのこの機能は、Entity Frameworkによって内部的に生成された同等のSQLクエリをキャプチャし、出力として提供することです。
  • Entity Framework 6より前は、データベースクエリとコマンドをトレースする必要があるときはいつでも、開発者にはサードパーティのトレースユーティリティまたはデータベーストレースツールを使用する以外の選択肢がありませんでした。
  • Entity Framework 6では、この新しい機能により、Entity Frameworkによって実行されたすべての操作をログに記録する簡単な方法が提供されます。
  • Entity Frameworkによって実行されるすべてのアクティビティは、DbContext.Database.Logを使用して記録されます。

新しい生徒がデータベースに追加される次のコードを見てみましょう。

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Database.Log = Console.Write;

        //Create a new student and save it

         context.Students.Add(new Student {
            FirstMidName = "Salman",
            LastName = "Khan",
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         context.SaveChanges();
         Console.ReadKey();
      }
   }
}

上記のコードが実行されると、次の出力を受け取ります。これは、実際には上記のコードでEFによって実行されたすべてのアクティビティのログです。

Opened connection at 10/28/2015 6:27:35 PM +05:00
Started transaction at 10/28/2015 6:27:35 PM +05:00
INSERT [dbo].[Student]([LastName], [FirstMidName], [EnrollmentDate])
VALUES (@0, @1, @2)
SELECT [ID]
FROM [dbo].[Student]
WHERE @@ROWCOUNT > 0 AND [ID] = scope_identity()
-- @0: 'Khan' (Type = String, Size = -1)
-- @1: 'Salman' (Type = String, Size = -1)
-- @2: '10/28/2015 12:00:00 AM' (Type = DateTime)
-- Executing at 10/28/2015 6:27:35 PM +05:00
-- Completed in 5 ms with result: SqlDataReader
Committed transaction at 10/28/2015 6:27:35 PM +05:00
Closed connection at 10/28/2015 6:27:35 PM +05:00

ログプロパティが設定されている場合、次のアクティビティがログに記録されます-

  • すべての異なる種類のコマンド用のSQL SaveChangesの一部として生成された挿入、更新、削除を含むクエリ
  • パラメーター
  • コマンドが非同期に実行されているかどうか
  • コマンドがいつ実行を開始したかを示すタイムスタンプ
  • コマンドは正常に完了または失敗しました
  • 結果値のいくつかの表示
  • コマンドの実行にかかったおおよその時間

他の場所へのロギング

既にロギングフレームワークがあり、ロギングメソッドが定義されている場合は、他の場所にロギングすることもできます。

別のクラスMyLoggerがある次の例を見てみましょう。

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         context.Database.Log = s ⇒ MyLogger.Log("EFLoggingDemo", s);

        //Create a new student and save it

         context.Students.Add(new Student {
            FirstMidName = "Salman",
            LastName = "Khan",
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
         });

         context.SaveChanges();
         Console.ReadKey();
      }
   }
}

public class MyLogger {

   public static void Log(string application, string message) {
      Console.WriteLine("Application: {0}, EF Message: {1} ",application, message);
   }
}

理解を深めるために、上記の例を段階的に実行することをお勧めします。