- 实体框架教程
- 实体框架 - 主页
- 实体框架 - 概述
- 实体框架 - 架构
- 实体框架 - 环境设置
- 实体框架 - 数据库设置
- 实体框架 - 数据模型
- 实体框架 - DbContext
- 实体框架 - 类型
- 实体框架 - 关系
- 实体框架 - 生命周期
- 实体框架 - Code First 方法
- 实体框架 - Model First 方法
- 实体框架 - Database First 方法
- 实体框架 - 开发方法
- 实体框架 - 数据库操作
- 实体框架 - 并发
- 实体框架 - 事务
- 实体框架 - 视图
- 实体框架 - 索引
- 实体框架 - 存储过程
- 实体框架 - 断开连接的实体
- 实体框架 - 表值函数
- 实体框架 - 本机 SQL
- 实体框架 - 枚举支持
- 实体框架 - 异步查询
- 实体框架 - 持久性
- 实体框架 - 投影查询
- 实体框架 - 命令记录
- 实体框架 - 命令拦截
- 实体框架 - 空间数据类型
- 实体框架 - 继承
- 实体框架 - 迁移
- 实体框架 - 热切加载
- 实体框架 - 延迟加载
- 实体框架 - 显式加载
- 实体框架 - 验证
- 实体框架 - 跟踪变更
- 实体框架 - 彩色实体
- 实体框架 - Code First 方法
- 实体框架 - 第一个示例
- 实体框架 - 数据注释
- 实体框架 - Fluent API
- 实体框架 - 种子数据库
- 实体框架 - Code First 迁移
- 实体框架 - 多个 DbContext
- 实体框架 - 嵌套实体类型
- 实体框架资源
- 实体框架 - 快速指南
- 实体框架 - 有用资源
- 实体框架 - 讨论
实体框架 - 命令记录
在 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); } }
我们建议你逐步执行以上示例,以便更好地理解。
广告