實體框架 - 命令記錄



在 Entity Framework 6.0 中,引入了一項稱為“Logging SQL”的新功能。在使用 Entity Framework 時,它會向資料庫傳送命令或等效的 SQL 查詢以執行 CRUD(建立、讀取、更新和刪除)操作。

  • 此 Entity Framework 功能旨在捕獲 Entity Framework 在內部生成的等效 SQL 查詢,並將其作為輸出提供。

  • 在 Entity Framework 6 之前,每當需要跟蹤資料庫查詢和命令時,開發人員別無選擇,只能使用某些第三方跟蹤實用程式或資料庫跟蹤工具。

  • 在 Entity Framework 6 中,此新功能透過記錄 Entity Framework 執行的所有操作提供了一種簡單的方法。

  • 使用 DbContext.Database.Log 記錄了 Entity Framework 執行的所有活動。

讓我們看一下以下程式碼,其中向資料庫添加了一個新學生。

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

設定 Log 屬性時記錄了以下活動:

  • 所有不同型別命令的 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);
   }
}

我們建議你逐步執行以上示例,以便更好地理解。

廣告
© . All rights reserved.