📜  Entity Framework-命令记录

📅  最后修改于: 2020-11-21 07:26:19             🧑  作者: Mango


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

我们建议您逐步执行上述示例,以更好地理解。