एंटिटी फ्रेमवर्क - पहला उदाहरण

कक्षाओं का उपयोग करते हुए एक बहुत ही सरल मॉडल को परिभाषित करते हैं। हम उन्हें सिर्फ Program.cs फ़ाइल में परिभाषित कर रहे हैं, लेकिन एक वास्तविक दुनिया के अनुप्रयोग में आप अपनी कक्षाओं को अलग-अलग फ़ाइलों और संभवतः एक अलग प्रोजेक्ट में विभाजित करेंगे। निम्नलिखित एक डेटा मॉडल है जिसे हम कोड प्रथम दृष्टिकोण का उपयोग करके बना रहे हैं।

मॉडल बनाएं

छात्र वर्ग के लिए निम्नलिखित कोड का उपयोग करके Program.cs फ़ाइल में निम्न तीन कक्षाएं जोड़ें।

public class Student {
   public int ID { get; set; }
   public string LastName { get; set; }
   public string FirstMidName { get; set; }
   public DateTime EnrollmentDate { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}
  • ID गुण डेटाबेस तालिका का प्राथमिक कुंजी स्तंभ बन जाएगा जो इस वर्ग से मेल खाता है।

  • नामांकन संपत्ति एक नेविगेशन संपत्ति है। नेविगेशन गुण अन्य संस्थाएं हैं जो इस इकाई से संबंधित हैं।

  • इस स्थिति में, एक छात्र इकाई की नामांकन संपत्ति उस छात्र इकाई से संबंधित सभी नामांकन संस्थाएं रखेगी।

  • नेविगेशन गुणों को आमतौर पर वर्चुअल के रूप में परिभाषित किया जाता है ताकि वे कुछ एंटिटी फ्रेमवर्क कार्यक्षमता जैसे आलसी लोडिंग का लाभ उठा सकें।

  • यदि एक नेविगेशन संपत्ति कई संस्थाओं (जैसे कई-से-कई या एक-टोमनी रिश्तों में) को धारण कर सकती है, तो इसका प्रकार एक सूची होना चाहिए जिसमें प्रविष्टियों को जोड़ा, हटाया, और अद्यतन किया जा सकता है, जैसे कि ICollection।

निम्नलिखित पाठ्यक्रम वर्ग के लिए कार्यान्वयन है।

public class Course {
   public int CourseID { get; set; }
   public string Title { get; set; }
   public int Credits { get; set; }
	
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

नामांकन संपत्ति एक नेविगेशन संपत्ति है। एक कोर्स इकाई किसी भी संख्या में नामांकन संस्थाओं से संबंधित हो सकती है।

निम्नलिखित नामांकन वर्ग और एनम के लिए कार्यान्वयन है।

public enum Grade {
   A, B, C, D, F
}

public class Enrollment {
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }
	
   public virtual Course Course { get; set; }
   public virtual Student Student { get; set; }
}
  • एनरोलमेंटआईडी संपत्ति प्राथमिक कुंजी होगी।

  • ग्रेड संपत्ति एक एनम है। ग्रेड प्रकार की घोषणा के बाद प्रश्न चिह्न इंगित करता है कि ग्रेड संपत्ति अशक्त है।

  • एक ग्रेड जो शून्य है वह एक शून्य ग्रेड से अलग है। नल का मतलब है कि एक ग्रेड ज्ञात नहीं है या अभी तक असाइन नहीं किया गया है।

  • स्टूडेंट और कोर्सिड प्रॉपर्टीज विदेशी चाबियां हैं, और संबंधित नेविगेशन प्रॉपर्टीज स्टूडेंट और कोर्स हैं।

  • एक नामांकन इकाई एक छात्र और एक पाठ्यक्रम इकाई से जुड़ी होती है, इसलिए संपत्ति केवल एक छात्र और पाठ्यक्रम इकाई रख सकती है।

डेटाबेस संदर्भ बनाएँ

मुख्य वर्ग जो किसी दिए गए डेटा मॉडल के लिए एंटिटी फ्रेमवर्क कार्यक्षमता का समन्वय करता है, डेटाबेस संदर्भ वर्ग है जो डेटा को क्वेरी और सहेजने की अनुमति देता है। आप इस क्लास को DbContext क्लास से प्राप्त करके और टाइप किए गए DbSet को उजागर करके बना सकते हैं हमारे मॉडल में प्रत्येक वर्ग के लिए। निम्नलिखित MyContext वर्ग पर कार्यान्वयन है, जो DbContext वर्ग से लिया गया है।

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

Program.cs फ़ाइल में पूर्ण कोड निम्नलिखित है।

using System.ComponentModel.DataAnnotations.Schema;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace EFCodeFirstDemo {

   class Program {
      static void Main(string[] args) {}
   }

   public enum Grade {
      A, B, C, D, F
   }

   public class Enrollment {
      public int EnrollmentID { get; set; }
      public int CourseID { get; set; }
      public int StudentID { get; set; }
      public Grade? Grade { get; set; }
		
      public virtual Course Course { get; set; }
      public virtual Student Student { get; set; }
   }

   public class Student {
      public int ID { get; set; }
      public string LastName { get; set; }
      public string FirstMidName { get; set; }
      public DateTime EnrollmentDate { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

   public class Course {
      public int CourseID { get; set; }
      public string Title { get; set; }
      public int Credits { get; set; }
		
      public virtual ICollection<Enrollment> Enrollments { get; set; }
   }

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

}

उपरोक्त कोड हम सभी को डेटा संग्रहीत करने और पुनर्प्राप्त करने की आवश्यकता है। आइए कुछ डेटा जोड़ें और फिर इसे पुनः प्राप्त करें। निम्नलिखित मुख्य विधि में कोड है।

static void Main(string[] args) {

   using (var context = new MyContext()) {
      // Create and save a new Students
      Console.WriteLine("Adding new students");

      var student = new Student {
         FirstMidName = "Alain", LastName = "Bomer", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      };

      context.Students.Add(student);
		
      var student1 = new Student {
         FirstMidName = "Mark", LastName = "Upston", 
            EnrollmentDate = DateTime.Parse(DateTime.Today.ToString())
      };

      context.Students.Add(student1);
      context.SaveChanges();

      // Display all Students from the database
      var students = (from s in context.Students 
         orderby s.FirstMidName select s).ToList<Student>();

      Console.WriteLine("Retrieve all Students from the database:");

      foreach (var stdnt in students) {
         string name = stdnt.FirstMidName + " " + stdnt.LastName;
         Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
      }
		
      Console.WriteLine("Press any key to exit...");
      Console.ReadKey();
   }
}

जब उपरोक्त कोड निष्पादित किया जाता है, तो आपको निम्न आउटपुट प्राप्त होगा।

Adding new students
Retrieve all Students from the database:
ID: 1, Name: Alain Bomer
ID: 2, Name: Mark Upston
Press any key to exit...

अब जो सवाल दिमाग में आता है वह है डेटा और डेटाबेस जिसमें हमने कुछ डेटा जोड़े हैं और फिर इसे डेटाबेस से पुनर्प्राप्त किया है। सम्मेलन द्वारा, DbContext ने आपके लिए एक डेटाबेस बनाया है।

  • यदि कोई स्थानीय SQL एक्सप्रेस उदाहरण उपलब्ध है, तो कोड पहले ने उस उदाहरण पर डेटाबेस बनाया है।

  • यदि SQL Express उपलब्ध नहीं है, तो कोड फर्स्ट LocalDb का उपयोग करने का प्रयास करेगा।

  • डेटाबेस का नाम व्युत्पन्न संदर्भ के पूरी तरह से योग्य नाम के बाद रखा गया है।

हमारे मामले में, SQL एक्सप्रेस उदाहरण उपलब्ध है, और डेटाबेस का नाम EFCodeFirstDemo.MyContext है जैसा कि निम्नलिखित छवि में दिखाया गया है।

  • ये केवल डिफ़ॉल्ट सम्मेलनों हैं और डेटाबेस को बदलने के लिए कई तरीके हैं जो कोड पहले का उपयोग करता है।

  • जैसा कि आप ऊपर की छवि में देख सकते हैं, इसने छात्रों, पाठ्यक्रम और नामांकन तालिकाएँ बनाई हैं और प्रत्येक तालिका में उपयुक्त डेटाटाइप और लंबाई वाले कॉलम हैं।

  • कॉलम नाम और डेटाटाइप भी संबंधित डोमेन कक्षाओं के गुणों से मेल खाते हैं।

डेटाबेस इनिशियलाइज़ेशन

उपरोक्त उदाहरण में, हमने देखा है कि कोड फर्स्ट स्वचालित रूप से एक डेटाबेस बनाता है, लेकिन यदि आप डेटाबेस और सर्वर का नाम बदलना चाहते हैं, तो आइए देखते हैं कि कैसे कोड फर्स्ट डेटाबेस को शुरू करते समय डेटाबेस का नाम और सर्वर तय करता है। निम्नलिखित आरेख पर एक नज़र डालें।

आप निम्न तरीकों से संदर्भ वर्ग के आधार निर्माता को परिभाषित कर सकते हैं।

  • कोई पैरामीटर नहीं
  • डेटाबेस नाम
  • कनेक्शन स्ट्रिंग नाम

कोई पैरामीटर नहीं

यदि आप उपरोक्त उदाहरण में दिखाए गए अनुसार किसी भी पैरामीटर के बिना संदर्भ वर्ग के बेस कंस्ट्रक्टर को निर्दिष्ट करते हैं, तो इकाई रूपरेखा आपके स्थानीय SQLEXPRESS सर्वर में {Namespace} नाम {Context class name} नाम से एक डेटाबेस बनाएगी।

उपरोक्त उदाहरण में, जो डेटाबेस स्वचालित रूप से बनाया गया है उसका नाम EFCodeFirstDemo.MyContext है। यदि आप नाम देखेंगे, तो आप पाएंगे कि EFCodeFirstDemo नाम स्थान है और MyContext संदर्भ वर्ग का नाम है जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class MyContext : DbContext {
   public MyContext() : base() {}

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

डेटाबेस नाम

यदि आप संदर्भ वर्ग के बेस कंस्ट्रक्टर में एक पैरामीटर के रूप में डेटाबेस का नाम पास करते हैं, तो कोड फर्स्ट फिर से स्वचालित रूप से एक डेटाबेस बनाएगा, लेकिन इस बार नाम स्थानीय SQLEXPRESS डेटाबेस सर्वर पर बेस कंस्ट्रक्टर में पैरामीटर के रूप में पारित किया जाएगा। ।

निम्नलिखित कोड में, MyContextDB को बेस कंस्ट्रक्टर में पैरामीटर के रूप में निर्दिष्ट किया गया है। यदि आप अपना एप्लिकेशन चलाते हैं, तो MyContextDB नाम वाला डेटाबेस आपके स्थानीय SQL सर्वर में बनाया जाएगा।

public class MyContext : DbContext {
   public MyContext() : base("MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}

कनेक्शन स्ट्रिंग नाम

यह DbContext को SQL Express या LocalDb के अलावा किसी डेटाबेस सर्वर का उपयोग करने का एक आसान तरीका है। आप अपनी ऐप में एक कनेक्शन स्ट्रिंग रखना चुन सकते हैं। फाइल फाइल।

  • यदि कनेक्शन स्ट्रिंग का नाम आपके संदर्भ के नाम से मेल खाता है (या तो नामस्थान योग्यता के साथ या बिना), तो यह DbContext द्वारा पाया जाएगा जब पैरामीटर कम कंस्ट्रक्टर का उपयोग किया जाता है।

  • यदि कनेक्शन स्ट्रिंग नाम आपके संदर्भ के नाम से अलग है, तो आप DbContext कंस्ट्रक्टर को कनेक्शन स्ट्रिंग नाम पास करके कोड फर्स्ट मोड में इस कनेक्शन का उपयोग करने के लिए कह सकते हैं।

public class MyContext : DbContext {
   public MyContext() : base("name = MyContextDB") {}
   public virtual DbSet<Course> Courses { get; set; }
   public virtual DbSet<Enrollment> Enrollments { get; set; }
   public virtual DbSet<Student> Students { get; set; }
}
  • उपरोक्त कोड में, बेस कंस्ट्रक्टर में एक पैरामीटर के रूप में संदर्भ वर्ग कनेक्शन स्ट्रिंग का स्निपेट निर्दिष्ट किया गया है।

  • कनेक्शन स्ट्रिंग नाम "नाम =" से शुरू होना चाहिए अन्यथा, यह एक डेटाबेस नाम के रूप में विचार करेगा।

  • यह फ़ॉर्म यह स्पष्ट करता है कि आप अपनी स्ट्रिंग फ़ाइल में कनेक्शन स्ट्रिंग के मिलने की उम्मीद करते हैं। एक अपवाद दिया जाएगा यदि दिए गए नाम के साथ एक कनेक्शन स्ट्रिंग नहीं मिला।

<connectionStrings>
   <add name = "MyContextDB"
      connectionString = "Data Source =.;Initial Catalog = EFMyContextDB;Integrated Security = true"
      providerName = "System.Data.SqlClient"/>
</connectionStrings>
  • App.config में कनेक्शन स्ट्रिंग में डेटाबेस का नाम है EFMyContextDB। CodeFirst एक नया निर्माण करेगाEFMyContextDB डेटाबेस या मौजूदा का उपयोग करें EFMyContextDB स्थानीय SQL सर्वर पर डेटाबेस।

डोमेन कक्षाएं

अब तक हमने EF को अपने डिफ़ॉल्ट सम्मेलनों का उपयोग करके मॉडल की खोज करने दिया है, लेकिन कई बार ऐसा भी होता है जब हमारी कक्षाएं सम्मेलनों का पालन नहीं करती हैं और हमें आगे कॉन्फ़िगरेशन करने में सक्षम होने की आवश्यकता होती है। लेकिन आप अपनी आवश्यकताओं की जानकारी के साथ ईएफ प्रदान करने के लिए अपने डोमेन कक्षाओं को कॉन्फ़िगर करके इन सम्मेलनों को ओवरराइड कर सकते हैं। आपके डोमेन वर्गों को कॉन्फ़िगर करने के लिए दो विकल्प हैं -

  • डेटा एनोटेशन
  • धाराप्रवाह एपीआई

डेटा एनोटेशन

DataAnnotations का उपयोग आपकी कक्षाओं को कॉन्फ़िगर करने के लिए किया जाता है जो सबसे अधिक आवश्यक कॉन्फ़िगरेशन को उजागर करेगा। DataAnnotations को ASP.NET MVC जैसे .NET अनुप्रयोगों की संख्या से भी समझा जाता है, जो इन अनुप्रयोगों को क्लाइंट-साइड सत्यापन के लिए समान एनोटेशन का लाभ उठाने की अनुमति देते हैं।

छात्र वर्ग में उपयोग किए जाने वाले डेटा एनोटेशन निम्नलिखित हैं।

public class Enrollment {

   [Key]
   public int EnrollmentID { get; set; }
   public int CourseID { get; set; }
   public int StudentID { get; set; }
   public Grade? Grade { get; set; }

   [ForeignKey("CourseID")]
   public virtual Course Course { get; set; }

   [ForeignKey("ID")]
   public virtual Student Student { get; set; }
}

धाराप्रवाह एपीआई

अधिकांश मॉडल कॉन्फ़िगरेशन को सरल डेटा एनोटेशन का उपयोग करके किया जा सकता है। धाराप्रवाह एपीआई मॉडल कॉन्फ़िगरेशन को निर्दिष्ट करने का एक उन्नत तरीका है जो डेटा एनोटेशन के साथ संभव नहीं होने वाले कुछ और उन्नत कॉन्फ़िगरेशन के अलावा, डेटा एनोटेशन को कवर कर सकता है। डेटा एनोटेशन और धाराप्रवाह एपीआई का एक साथ उपयोग किया जा सकता है।

धाराप्रवाह एपीआई तक पहुँचने के लिए आप DbContext में OnModelCreating विधि को ओवरराइड करते हैं। अब FirstMidName से FirstName तक छात्र तालिका में कॉलम का नाम बदलें जैसा कि निम्नलिखित कोड में दिखाया गया है।

public class MyContext : DbContext {

   protected override void OnModelCreating(DbModelBuilder modelBuilder) {
      modelBuilder.Entity<Student>().Property(s ⇒ s.FirstMidName)
         .HasColumnName("FirstName");
   }

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