开发手册 欢迎您!
软件开发者资料库

Entity Framework - 命令记录

Entity Framework 命令日志记录 - 从概述,体系结构,环境设置,数据库设置,数据模型,DbContext,类型,关系,生命周期,代码优先方法,模型优先方法,数据库优先方法,DEV方法,数据库操作,并发开始学习实体框架,事务,视图,索引,存储过程,断开连接的实体,表值函数,本机SQL,枚举支持,异步查询,持久性,投影查询,命令记录,命令拦截,空间数据类型,继承,迁移,渴望,懒惰,显式加载,验证,跟踪更改,彩色实体,第一个示例,数据注释,Fluent API,种子数据库,代码优先迁移,多个DbContext,嵌套实体类型。

在Entity Framework 6.0中,引入了一项新功能,称为记录SQL .在使用Entity Framework时,它会向数据库发送命令或等效的SQL查询,以执行CRUD(创建,读取,更新和删除)操作.

  • 实体框架的这一特性是在内部捕获由Entity Framework生成的等效SQL查询并将其作为输出提供.

  • 在Entity Framework 6之前,只要需要跟踪数据库查询和命令,开发人员别无选择,只能使用某些第三方跟踪实用程序或数据库跟踪工具.

  • 在Entity Framework 6中,这个新功能通过记录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:00Started transaction at 10/28/2015 6:27:35 PM +05:00INSERT [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: SqlDataReaderCommitted transaction at 10/28/2015 6:27:35 PM +05:00Closed connection at 10/28/2015 6:27:35 PM +05:00

当Log属性设置为以下ac时记录和减去tivities;

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

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