इकाई ढांचा - संबंध

संबंधपरक डेटाबेस में, संबंध एक ऐसी स्थिति है जो विदेशी कुंजी के माध्यम से संबंधपरक डेटाबेस तालिकाओं के बीच मौजूद है। एक विदेशी कुंजी (FK) स्तंभों का एक संयोजन या संयोजन है जिसका उपयोग दो तालिकाओं में डेटा के बीच एक लिंक को स्थापित करने और लागू करने के लिए किया जाता है। निम्न आरेख में तीन तालिकाएँ हैं।

  • Student
  • Course
  • Enrollment

उपरोक्त आरेख में, आप तालिकाओं के बीच किसी प्रकार का संबंध / संबंध देख सकते हैं। तालिकाओं के बीच तीन प्रकार के संबंध हैं और विभिन्न तालिकाओं के बीच संबंध इस बात पर निर्भर करता है कि संबंधित स्तंभ कैसे परिभाषित किए जाते हैं।

  • एक से कई रिश्ते
  • कई-कई रिश्ते
  • वन-टू-वन रिलेशनशिप

एक से कई रिश्ते

  • एक से कई संबंध सबसे आम प्रकार का रिश्ता है।

  • इस प्रकार के संबंध में, तालिका A की एक पंक्ति में तालिका B में कई मिलान पंक्तियाँ हो सकती हैं, लेकिन तालिका B में एक पंक्ति में तालिका A में केवल एक मिलान पंक्ति हो सकती है।

  • विदेशी कुंजी को तालिका में परिभाषित किया गया है जो रिश्ते के कई अंत का प्रतिनिधित्व करता है।

  • उदाहरण के लिए, ऊपर दिए गए आरेख में छात्र और नामांकन तालिका में एक-टोमनी संबंध है, प्रत्येक छात्र के कई नामांकन हो सकते हैं, लेकिन प्रत्येक नामांकन केवल एक छात्र का है।

इकाई ढांचे में, इन संबंधों को कोड के साथ भी बनाया जा सकता है। निम्नलिखित छात्र और नामांकन कक्षाओं का एक उदाहरण है जो एक से कई संबंधों से जुड़े हैं।

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

उपरोक्त कोड में, आप देख सकते हैं कि छात्र वर्ग में नामांकन का संग्रह है, लेकिन नामांकन कक्षा में एक ही छात्र वस्तु है।

कई-कई रिश्ते

कई-से-कई संबंधों में, तालिका ए में एक पंक्ति में तालिका बी में कई मिलान पंक्तियाँ हो सकती हैं, और इसके विपरीत।

  • जंक्शन टेबल नामक तीसरी टेबल को परिभाषित करके आप ऐसा रिश्ता बना सकते हैं, जिसकी प्राथमिक कुंजी में टेबल ए और टेबल बी दोनों से विदेशी चाबियां होती हैं।

  • उदाहरण के लिए, छात्र और पाठ्यक्रम की तालिकाओं में कई-से-कई संबंध होते हैं जो इन तालिकाओं में से प्रत्येक से एक से कई संबंधों द्वारा नामांकन तालिका में परिभाषित किया जाता है।

निम्नलिखित कोड में पाठ्यक्रम वर्ग और उपरोक्त दो वर्ग शामिल हैं, अर्थात Student तथा Enrollment

public class Course {
   [DatabaseGenerated(DatabaseGeneratedOption.None)]
	
   public int CourseID { get; set; }
   public string Title { get; set; }
	
   public int Credits { get; set; } 
   public virtual ICollection<Enrollment> Enrollments { get; set; }
}

आप देख सकते हैं कि कोर्स क्लास और स्टूडेंट क्लास दोनों में एनरोलमेंट ऑब्जेक्ट्स का संग्रह है जो जंक्शन क्लास एनरोलमेंट के माध्यम से कई-से-कई संबंध बनाता है।

वन-टू-वन रिलेशनशिप

  • एक-से-एक रिश्ते में, तालिका ए में एक पंक्ति में तालिका बी में एक से अधिक मिलान पंक्ति नहीं हो सकती है, और इसके विपरीत।

  • एक-से-एक संबंध बनाया जाता है यदि दोनों संबंधित स्तंभ प्राथमिक कुंजी हैं या अद्वितीय अवरोध हैं।

  • एक-से-एक रिश्ते में, प्राथमिक कुंजी अतिरिक्त रूप से एक विदेशी कुंजी के रूप में कार्य करती है और दोनों तालिका के लिए कोई अलग विदेशी कुंजी स्तंभ नहीं है।

इस प्रकार का संबंध सामान्य नहीं है क्योंकि इस तरह से संबंधित अधिकांश जानकारी एक ही तालिका में होगी। आप एक-से-एक संबंध का उपयोग कर सकते हैं -

  • कई स्तंभों के साथ एक तालिका को विभाजित करें।
  • सुरक्षा कारणों से एक तालिका का अलग भाग।
  • स्टोर डेटा जो अल्पकालिक है और आसानी से तालिका को हटाकर आसानी से हटाया जा सकता है।
  • ऐसी जानकारी संग्रहीत करें जो केवल मुख्य तालिका के सबसेट पर लागू होती है।

निम्नलिखित कोड एक और वर्ग का नाम जोड़ने के लिए है StudentProfile जिसमें छात्र ईमेल आईडी और पासवर्ड होता है।

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 virtual StudentProfile StudentProfile { get; set; }
}

public class StudentProfile {

   public StudentProfile() {}
   public int ID { get; set; }
   public string Email { get; set; }
   public string Password { get; set; }
	
   public virtual Student Student { get; set; }
}

आप देख सकते हैं कि छात्र इकाई वर्ग में स्टूडेंटप्रोफाइल नेविगेशन प्रॉपर्टी है और स्टूडेंटप्रोफाइल में स्टूडेंट नेविगेशन प्रॉपर्टी है।

प्रत्येक छात्र के पास विश्वविद्यालय डोमेन में प्रवेश करने के लिए केवल एक ईमेल और पासवर्ड है। इन सूचनाओं को छात्र तालिका में जोड़ा जा सकता है लेकिन सुरक्षा कारणों से इसे दूसरी तालिका में अलग कर दिया जाता है।