NHibernate - संग्रह मानचित्रण

इस अध्याय में, हम संग्रह का प्रतिनिधित्व करने के तरीके को कवर करेंगे। विभिन्न प्रकार के संग्रह हैं जिन्हें हम NHibernate के भीतर उपयोग कर सकते हैं जैसे कि -

  • Lists
  • Sets
  • Bags

अब, .NET परिप्रेक्ष्य से, हम आम तौर पर सूचियों से निपटते हैं या बहुत ही सरल डेटा संरचनाओं, सूचियों, शब्दकोशों की तरह। .NET में विभिन्न प्रकार के संग्रह की एक विस्तृत विविधता नहीं है। तो NHibernate को इन सभी विभिन्न प्रकारों की आवश्यकता क्यों है? यह वास्तव में डेटाबेस में वापस आता है।

सूची

  • एक सूची उन तत्वों का एक संग्रहित संग्रह है जो आवश्यक रूप से अद्वितीय नहीं हैं।

  • हम इसका उपयोग करके नक्शा कर सकते हैं IList <T>

  • इसलिए यद्यपि हमारे पास पारंपरिक रूप से पते की एक सूची हो सकती है, और आवेदन के दृष्टिकोण से हम जानते हैं कि तत्व अद्वितीय हैं, सूची में कुछ भी हमें उस सूची में डुप्लिकेट तत्वों को सम्मिलित करने से नहीं रोकता है।

सेट

  • एक सेट अद्वितीय तत्वों का एक अनियंत्रित संग्रह है। यदि आप एक सेट में 2 डुप्लिकेट तत्वों को सम्मिलित करने का प्रयास करते हैं, तो यह एक अपवाद फेंक देगा।

  • इसके बारे में NHibernate में कुछ खास नहीं है।

  • यह सिर्फ एक सुविधाजनक तरीका है एक सामान्य सेट कार्यान्वयन है। यदि आप .NET 4 पर हैं, तो आप नए का उपयोग कर सकते हैंHashSet <T> इनका प्रतिनिधित्व करने के लिए, लेकिन अधिकांश NHibernate अनुप्रयोगों में, हम प्रतिनिधित्व करते हैं कि यह एक ISet है।

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

  • तो सामान्य तौर पर, आप जिस डेटा को डेटाबेस से वापस खींच रहे हैं वह सेट है।

  • वे तत्वों के अनूठे संग्रह हैं जो अनियंत्रित हैं।

बैग

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

  • .NET की दुनिया में, हम एक IList द्वारा इसका प्रतिनिधित्व करते हैं।

सेट शायद सबसे आम हैं, लेकिन आप अपने आवेदन के आधार पर सूची और बैग देखेंगे। नीचे एक नजर डालते हैंcustomer.hbm.xml अंतिम अध्याय से फ़ाइल जिसमें सेट आदेश परिभाषित किए गए हैं।

<?xml version = "1.0" encoding = "utf-8" ?> 
<hibernate-mapping xmlns = "urn:nhibernate-mapping-2.2" assembly = "NHibernateDemo" 
   namespace = "NHibernateDemo"> 
	
   <class name = "Customer"> 
      
      <id name = "Id"> 
         <generator class = "guid.comb"/> 
      </id> 
   
      <property name = "FirstName"/> 
      <property name = "LastName"/> 
      <property name = "AverageRating"/> 
      <property name = "Points"/> 
      <property name = "HasGoldStatus"/> 
      <property name = "MemberSince" type = "UtcDateTime"/> 
      <property name = "CreditRating" type = "CustomerCreditRatingType"/>
      
      <component name = "Address"> 
         <property name = "Street"/> 
         <property name = "City"/> 
         <property name = "Province"/> 
         <property name = "Country"/> 
      </component>
      
      <set name = "Orders" table = "`Order`"> 
         <key column = "CustomerId"/> 
         <one-to-many class = "Order"/> 
      </set> 
   
   </class> 
</hibernate-mapping>

जैसा कि आप देख सकते हैं, हमने एक सेट के रूप में ऑर्डर संग्रह को मैप किया है। याद रखें कि एक सेट अद्वितीय तत्वों का एक अनियंत्रित संग्रह है।

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

public virtual ISet<Order> Orders { get; set; }

अब जब यह एप्लिकेशन चलाया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

New Customer:
John Doe (00000000-0000-0000-0000-000000000000)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Unspecified)
   CreditRating: Good
   AverageRating: 42.42424242

   Orders:
      Order Id: 00000000-0000-0000-0000-000000000000
      Order Id: 00000000-0000-0000-0000-000000000000

Reloaded:
John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
      Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7

The orders were ordered by:
John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
      Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7

John Doe (1f248133-b50a-4ad7-9915-a5b8017d0ff1)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: c41af8f2-7124-42a7-91c5-a5b8017d0ff6
      Order Id: 657f6bb0-1f42-45fc-8fc7-a5b8017d0ff7
		
Press <ENTER> to exit...

यदि संग्रह में मौजूद वस्तुओं को विशिष्ट होने की आवश्यकता नहीं है, यदि आपके पास इस संग्रह में कई बार होने वाली एक ही प्राथमिक कुंजी के साथ कई आदेश हो सकते हैं, तो यह एक बैग के रूप में बेहतर मैप किया जाएगा जैसा कि निम्नलिखित कार्यक्रम में दिखाया गया है।

<bag name = "Orders" table = "`Order`"> 
   <key column = "CustomerId"/> 
   <one-to-many class = "Order"/> 
</bag>

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

इसलिए हमें इसे एक IList में बदलना होगा और फिर यहां, हमें HashSet से एक सूची में कंस्ट्रक्टर में बदलना होगा।

public class Customer { 

   public Customer() { 
      MemberSince = DateTime.UtcNow; 
      Orders = new List<Order>(); 
   } 
	
   public virtual Guid Id { get; set; } 
   public virtual string FirstName { get; set; } 
   public virtual string LastName { get; set; } 
   public virtual double AverageRating { get; set; } 
   public virtual int Points { get; set; } 
	
   public virtual bool HasGoldStatus { get; set; } 
   public virtual DateTime MemberSince { get; set; } 
   public virtual CustomerCreditRating CreditRating { get; set; } 
   public virtual Location Address { get; set; }
   public virtual IList<Order> Orders { get; set; }
   public virtual void AddOrder(Order order) { Orders.Add(order); order.Customer = this; }
   
   public override string ToString() { 
      var result = new StringBuilder(); 
		
      result.AppendFormat("{1} {2} ({0})\r\n\tPoints: {3}\r\n\tHasGoldStatus:
         {4}\r\n\tMemberSince: {5} ({7})\r\n\tCreditRating: {6}\r\n\tAverageRating:
         {8}\r\n", Id, FirstName, LastName, Points, HasGoldStatus, MemberSince,
         CreditRating, MemberSince.Kind, AverageRating); result.AppendLine("\tOrders:"); 
      
      foreach(var order in Orders) { 
         result.AppendLine("\t\t" + order); 
      } 
		
      return result.ToString(); 
   } 
}

जब आप एप्लिकेशन चलाते हैं, तो आपको वही व्यवहार दिखाई देगा। लेकिन, अब हमारे पास एक ही संग्रह में कई बार होने वाला एक आदेश हो सकता है।

John Doe (00000000-0000-0000-0000-000000000000)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Unspecified)
   CreditRating: Good
   AverageRating: 42.42424242

   Orders:
      Order Id: 00000000-0000-0000-0000-000000000000
      Order Id: 00000000-0000-0000-0000-000000000000

Reloaded:
John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
      Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287

The orders were ordered by:
John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
      Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287

John Doe (fbde48f5-d620-4d1c-9a7f-a5b8017c3280)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: 6dd7dbdb-354f-4c82-9c39-a5b8017c3286
      Order Id: 9b3e2441-a81b-404d-9aed-a5b8017c3287
		
Press <ENTER> to exit...