Entity Framework - Komut Günlüğü

Entity Framework 6.0'da, olarak bilinen yeni bir özellik tanıtıldı Logging SQL. Entity Framework ile çalışırken, CRUD (Oluşturma, Okuma, Güncelleme ve Silme) işlemleri yapmak için veritabanına komutlar veya eşdeğer bir SQL sorgusu gönderir.

  • Entity Framework'ün bu özelliği, Entity Framework tarafından dahili olarak oluşturulan eşdeğer bir SQL sorgusunu yakalamak ve bunu çıktı olarak sağlamaktır.

  • Entity Framework 6'dan önce, veritabanı sorgularını ve komutlarını izleme ihtiyacı olduğunda, geliştiricinin bazı üçüncü taraf izleme yardımcı programını veya veritabanı izleme aracını kullanmaktan başka seçeneği yoktu.

  • Entity Framework 6'da bu yeni özellik, Entity Framework tarafından gerçekleştirilen tüm işlemleri günlüğe kaydederek basit bir yol sağlar.

  • Entity Framework tarafından gerçekleştirilen tüm etkinlikler DbContext.Database.Log kullanılarak günlüğe kaydedilir.

Veritabanına yeni bir öğrencinin eklendiği aşağıdaki koda bir göz atalım.

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

Yukarıdaki kod çalıştırıldığında, aslında yukarıdaki kodda EF tarafından gerçekleştirilen tüm etkinliklerin günlüğü olan aşağıdaki çıktıyı alacaksınız.

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 özelliği ayarlandığında aşağıdaki etkinlikler günlüğe kaydedilir -

  • SaveChanges'ın bir parçası olarak oluşturulan eklemeler, güncellemeler ve silmeler dahil olmak üzere tüm farklı komut türleri için SQL

  • Parameters

  • Komutun eşzamansız olarak yürütülüp yürütülmediği

  • Komutun ne zaman yürütülmeye başladığını gösteren bir zaman damgası

  • Komut başarıyla tamamlandı veya başarısız oldu

  • Sonuç değerinin bazı göstergeleri

  • Komutu çalıştırmak için geçen yaklaşık süre

Başka Bir Yerde Oturum Açma

Zaten bir günlükleme çerçeveniz varsa ve bu bir günlük tutma yöntemini tanımlıyorsa, başka bir yere de kaydedebilirsiniz.

Başka bir sınıf MyLogger'a sahip olduğumuz aşağıdaki örneğe bir göz atalım.

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

Daha iyi anlamak için yukarıdaki örneği adım adım uygulamanızı öneririz.