- 實體框架教程
- 實體框架 - 主頁
- 實體框架 - 概述
- 實體框架 - 架構
- 實體框架 - 環境設定
- 實體框架 - 資料庫設定
- 實體框架 - 資料模型
- 實體框架 - 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);
}
}
我們建議你逐步執行以上示例,以便更好地理解。
廣告