Entity Framework - Geç Yükleme

Geç yükleme, bir varlığın veya varlıklar koleksiyonunun, varlığa / varlıklara atıfta bulunan bir özelliğe ilk erişildiğinde veritabanından otomatik olarak yüklendiği işlemdir. Geç yükleme, siz özellikle talep edene kadar ilgili verilerin yüklenmesini geciktirmek anlamına gelir.

  • POCO varlık türlerini kullanırken, tembel yükleme, türetilmiş proxy türlerinin örneklerini oluşturarak ve ardından yükleme kancasını eklemek için sanal özellikleri geçersiz kılarak gerçekleştirilir.

  • Tembel yükleme hemen hemen varsayılandır.

  • Varsayılan yapılandırmayı bırakırsanız ve sorgunuzda Entity Framework'e tembel yüklemeden başka bir şey istediğinizi açıkça belirtmezseniz, alacağınız şey tembel yüklemedir.

  • Örneğin, Öğrenci varlık sınıfını kullanırken, ilgili Kayıtlar, Kayıtlar gezinme özelliğine ilk erişildiğinde yüklenecektir.

  • Gezinme özelliği genel, sanal olarak tanımlanmalıdır. Bağlam olacakNOT özellik sanal olarak tanımlanmamışsa geç yükleme yapın.

Aşağıda, Kayıtların gezinme özelliğini içeren bir Öğrenci sınıfı bulunmaktadır.

public partial class Student {

   public Student() {
      this.Enrollments = new HashSet<Enrollment>();
   }
	
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public System.DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

Önce öğrenci listesinin veritabanından yüklendiği ve daha sonra ihtiyaç duyduğunuzda belirli bir öğrencinin kayıtlarını yükleyeceği basit bir örneğe bakalım.

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         //Loading students only
         IList<Student> students = context.Students.ToList<Student>();

         foreach (var student in students) {

            string name = student.FirstMidName + " " + student.LastName;
            Console.WriteLine("ID: {0}, Name: {1}", student.ID, name);
	
            foreach (var enrollment in student.Enrollments) {
               Console.WriteLine("Enrollment ID: {0}, Course ID: {1}", 
                  enrollment.EnrollmentID, enrollment.CourseID);
            }
         }

         Console.ReadKey();
      }
   }
}

Yukarıdaki kod derlendiğinde ve yürütüldüğünde, aşağıdaki çıktıyı alacaksınız.

ID: 1, Name: Ali Alexander
       Enrollment ID: 1, Course ID: 1050
       Enrollment ID: 2, Course ID: 4022
       Enrollment ID: 3, Course ID: 4041
ID: 2, Name: Meredith Alonso
       Enrollment ID: 4, Course ID: 1045
       Enrollment ID: 5, Course ID: 3141
       Enrollment ID: 6, Course ID: 2021
ID: 3, Name: Arturo Anand
       Enrollment ID: 7, Course ID: 1050
ID: 4, Name: Gytis Barzdukas
       Enrollment ID: 8, Course ID: 1050
       Enrollment ID: 9, Course ID: 4022
ID: 5, Name: Yan Li
       Enrollment ID: 10, Course ID: 4041
ID: 6, Name: Peggy Justice
       Enrollment ID: 11, Course ID: 1045
ID: 7, Name: Laura Norman
       Enrollment ID: 12, Course ID: 3141

Geç Yüklemeyi Kapat

Tembel yükleme ve serileştirme iyi karışmaz ve dikkatli olmazsanız, yalnızca tembel yükleme etkinleştirildiği için tüm veritabanınızı sorgulayabilirsiniz. Bir varlığı serileştirmeden önce geç yüklemeyi kapatmak iyi bir uygulamadır.

Belirli Gezinme Özellikleri için Kapatma

Enrollments koleksiyonunun geç yüklenmesi, aşağıdaki örnekte gösterildiği gibi Enrollments özelliğini sanal olmayan hale getirerek kapatılabilir.

public partial class Student { 

   public Student() { 
      this.Enrollments = new HashSet<Enrollment>(); 
   }
	
   public int ID { get; set; } 
   public string LastName { get; set; } 
   public string FirstMidName { get; set; } 
   public System.DateTime EnrollmentDate { get; set; }
	
   public ICollection<Enrollment> Enrollments { get; set; } 
}

Tüm Varlıklar için Kapat

Aşağıdaki örnekte gösterildiği gibi Configuration özelliğindeki bir bayrak false olarak ayarlanarak geç yükleme bağlamdaki tüm varlıklar için kapatılabilir.

public partial class UniContextEntities : DbContext { 

   public UniContextEntities(): base("name = UniContextEntities") {
      this.Configuration.LazyLoadingEnabled = false;
   }
	
   protected override void OnModelCreating(DbModelBuilder modelBuilder) { 
      throw new UnintentionalCodeFirstException(); 
   } 
}

Geç yüklemeyi kapattıktan sonra, şimdi yukarıdaki örneği tekrar çalıştırdığınızda, Kayıtların yüklenmediğini ve sadece öğrenci verilerinin alındığını göreceksiniz.

ID: 1, Name: Ali Alexander
ID: 2, Name: Meredith Alons
ID: 3, Name: Arturo Anand
ID: 4, Name: Gytis Barzduka
ID: 5, Name: Yan Li
ID: 6, Name: Peggy Justice
ID: 7, Name: Laura Norman
ID: 8, Name: Nino Olivetto

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