एंटिटी फ्रेमवर्क - डेटाबेस ऑपरेशंस

पिछले अध्यायों में, आपने इकाई डेटा मॉडल को परिभाषित करने के तीन अलग-अलग तरीके सीखे।

  • उनमें से दो, डाटाबेस फर्स्ट और मॉडल फर्स्ट, कोड पीढ़ी के साथ संयुक्त एंटिटी फ्रेमवर्क डिजाइनर पर निर्भर थे।

  • तीसरा, कोड फर्स्ट, आपको एक विजुअल डिज़ाइनर को छोड़ देता है और सिर्फ अपना कोड लिखता है।

  • आप चाहे जो भी रास्ता चुनें, आप डोमेन कक्षाओं और एक या अधिक एंटिटी फ्रेमवर्क DbContext कक्षाओं के साथ समाप्त हो जाएंगे, जिससे आप उन कक्षाओं के लिए प्रासंगिक डेटा पुनः प्राप्त कर सकते हैं और बनाए रख सकते हैं।

आपके अनुप्रयोगों में DbContext API का उपयोग आपकी कक्षाओं और आपके डेटाबेस के बीच एक सेतु के रूप में किया जाता है। DbContext इकाई संरचना में सबसे महत्वपूर्ण वर्गों में से एक है।

  • यह प्रश्नों को व्यक्त और निष्पादित करने में सक्षम बनाता है।

  • यह डेटाबेस से क्वेरी परिणाम लेता है और उन्हें हमारे मॉडल कक्षाओं के उदाहरणों में बदल देता है।

  • यह जोड़ने और हटाने सहित संस्थाओं में परिवर्तन का ट्रैक रख सकता है, और फिर मांग पर डेटाबेस को भेजे गए बयानों को सम्मिलित करने, अद्यतन करने और हटाने के लिए ट्रिगर करता है।

निम्नलिखित डोमेन विज्ञापन संदर्भ कक्षाएं हैं जिनके आधार पर हम इस अध्याय में विभिन्न ऑपरेशन करेंगे। यह वही उदाहरण है जो हमने chapater, डेटाबेस फर्स्ट एप्रोच में बनाया है।

प्रसंग वर्ग कार्यान्वयन

using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Data.Entity.Core.Objects;
using System.Linq;

namespace DatabaseFirstDemo {

   public partial class UniContextEntities : DbContext {

      public UniContextEntities(): base("name = UniContextEntities") {}

      protected override void OnModelCreating(DbModelBuilder modelBuilder) {
         throw new UnintentionalCodeFirstException();
      }

      public virtual DbSet<Course> Courses { get; set; }
      public virtual DbSet<Enrollment> Enrollments { get; set; }
      public virtual DbSet<Student> Students { get; set; }
   }
}

डोमेन कक्षाएं कार्यान्वयन

कोर्स की क्लास

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic;
	
   public partial class Course {

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2214:DoNotCallOverridableMethodsInConstructors")]

      public Course() {
         this.Enrollments = new HashSet<Enrollment>();
      }
	
      public int CourseID { get; set; }
      public string Title { get; set; }
      public int Credits { get; set; }
	
      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2227:CollectionPropertiesShouldBeReadOnly")]
			
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }
}

छात्र वर्ग

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic; 

   public partial class Student {

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2214:DoNotCallOverridableMethodsInConstructors")]

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

      [System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage", 
         "CA2227:CollectionPropertiesShouldBeReadOnly")]
			
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }
}

नामांकन वर्ग

namespace DatabaseFirstDemo {

   using System;
   using System.Collections.Generic; 

   public partial class Enrollment {

      public int EnrollmentID { get; set; }
      public int CourseID { get; set; }
      public int StudentID { get; set; }
      public Nullable<int> Grade { get; set; }
		
      public virtual Course Course { get; set; }
      public virtual Student Student { get; set; }
   }
}

ऑपरेशन बनाएँ

एंटिटी फ्रेमवर्क के साथ एक नई वस्तु जोड़ना अपनी वस्तु के एक नए उदाहरण का निर्माण करने और इसे DSSet पर ऐड पद्धति का उपयोग करके पंजीकृत करने के रूप में सरल है। निम्न कोड आपको डेटाबेस में एक नया छात्र जोड़ने की सुविधा देता है।

class Program {

   static void Main(string[] args) {

      var newStudent = new Student();

      //set student name

      newStudent.FirstMidName = "Bill";
      newStudent.LastName = "Gates";
      newStudent.EnrollmentDate = DateTime.Parse("2015-10-21");
      newStudent.ID = 100;

      //create DBContext object

      using (var dbCtx = new UniContextEntities()) {

         //Add Student object into Students DBset
         dbCtx.Students.Add(newStudent);

         // call SaveChanges method to save student into database
         dbCtx.SaveChanges();
      }
   }
}

अद्यतन अद्यतन

मौजूदा ऑब्जेक्ट्स को बदलना उतना ही सरल है जितना कि उस संपत्ति को निर्दिष्ट मूल्य को अपडेट करना जो आप बदलना चाहते हैं और SaveChanges को कॉल कर रहे हैं। उदाहरण के लिए, अली से अंतिम नाम को खान से असलम में बदलने के लिए निम्न कोड का उपयोग किया जाता है।

using (var context = new UniContextEntities()) {

   var student = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
   student.LastName = "Aslam";
   context.SaveChanges();
}

ऑपरेशन हटाएँ

एंटिटी फ्रेमवर्क का उपयोग करके किसी इकाई को हटाने के लिए, आप DbSet पर निकालें विधि का उपयोग करें। मौजूदा और नए जोड़े गए दोनों संस्थाओं के लिए काम निकालें। निकाले गए निकाय पर कॉल करना जो जोड़ा गया है, लेकिन डेटाबेस में अभी तक सहेजा नहीं गया है, इकाई को जोड़ना रद्द कर देगा। इकाई को परिवर्तन ट्रैकर से हटा दिया जाता है और अब DbContext द्वारा ट्रैक नहीं किया जाता है। परिवर्तन-ट्रैक की जा रही मौजूदा इकाई पर कॉल को हटाने से अगली बार SaveChanges नामक विलोपन के लिए इकाई पंजीकृत हो जाएगी। निम्न उदाहरण एक कोड का है जहां छात्र डेटाबेस से हटा दिया जाता है जिसका पहला नाम अली है।

using (var context = new UniContextEntities()) {
   var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
   context.Students.Remove(bay);
   context.SaveChanges();
}

ऑपरेशन पढ़ें

डेटाबेस से मौजूदा डेटा को पढ़ना बहुत सरल है। निम्नलिखित कोड है जिसमें छात्र तालिका के सभी डेटा को पुनर्प्राप्त किया जाता है और फिर छात्रों के पहले और अंतिम नाम के साथ वर्णमाला क्रम में एक कार्यक्रम प्रदर्शित किया जाएगा।

using (var db = new UniContextEntities()) {

   var query = from b in db.Students orderby b.FirstMidName select b;
   Console.WriteLine("All All student in the database:");

   foreach (var item in query) {
      Console.WriteLine(item.FirstMidName +" "+ item.LastName);
   }

   Console.WriteLine("Press any key to exit...");
   Console.ReadKey();
}