NHibernate - कैस्केड

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

  • हम विदेशी प्रमुख बाधाओं का भी उल्लंघन कर सकते हैं, इसलिए हम कैस्केड की धारणा का उपयोग कर सकते हैं।

  • डिफ़ॉल्ट रूप से, NHibernate चाइल्ड ऑब्जेक्ट के लिए ऑपरेशन को कैस्केड नहीं करता है।

  • इसका कारण यह है कि आप एक ऐसे ग्राहक के रूप में संबंध बना सकते हैं, जिसमें एक डिफ़ॉल्ट शिपिंग पता है और वह शिपिंग पता कई अलग-अलग ग्राहकों के साथ साझा किया गया है।

  • इसलिए आप उस रिश्ते को समझना नहीं चाहेंगे क्योंकि अन्य ग्राहक अभी भी इसका जिक्र कर रहे हैं।

  • तो कैस्केड की पूरी धारणा NHibernate को यह बताना है कि अपने बच्चे को कैसे संभालना है।

कैस्केडिंग के लिए अलग-अलग विकल्प हैं, जो इस प्रकार हैं -

  • none - जो डिफ़ॉल्ट है और इसका मतलब है कोई कैस्केडिंग नहीं है।

  • all - जो कैस्केड करने जा रहा है, वह अपडेट, अपडेट और डिलीट हो जाता है।

  • save-update - यह झरना, बचाता है और अद्यतन करेगा।

  • delete - यह कैस्केड हटा देगा।

  • all-delete-orphan - यह एक विशेष है जो काफी बार उपयोग किया जाता है और सभी को छोड़कर समान है, यदि यह डिलीट-अनाथ पंक्तियों को पाता है, तो यह उन लोगों को भी हटा देगा।

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

आइए सरल उदाहरण कैस्केड में देखें, चलो प्रोग्राम में समस्या को ठीक करते हैं, जहां हमें निम्नलिखित कोड में दिखाए गए आदेशों को मैन्युअल रूप से सहेजना है।

using(var session = sessionFactory.OpenSession()) 

using(var tx = session.BeginTransaction()) { 
   var newCustomer = CreateCustomer(); 
   Console.WriteLine("New Customer:"); 
   Console.WriteLine(newCustomer); 
   session.Save(newCustomer); 
	
   foreach (var order in newCustomer.Orders) { 
      session.Save(order); 
   } 
	
   id = newCustomer.Id; 
   tx.Commit(); 
}

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

using(var session = sessionFactory.OpenSession())
 
using(var tx = session.BeginTransaction()) { 
   var newCustomer = CreateCustomer(); 
   Console.WriteLine("New Customer:"); 
   Console.WriteLine(newCustomer);
	
   session.Save(newCustomer); 
   id = newCustomer.Id; 
   tx.Commit(); 
}

हमें कैस्केड विकल्प निर्दिष्ट करने की आवश्यकता है 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`" cascade = "all-delete-orphan"> 
         <key column = "CustomerId"/> 
         <one-to-many class = "Order"/> 
      </set> 
   
   </class> 
</hibernate-mapping>
  • अब, ऑर्डर पूरी तरह से ग्राहक के हैं। इसलिए यदि ग्राहकों को डेटाबेस से हटा दिया गया था, तो यहां हमारा एप्लिकेशन उन सभी आदेशों को हटाना चाहता है, जिनमें कोई भी अनाथ हो सकता है।

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

  • तो आप वास्तव में इन डिलीट को कैस्केड कर सकते हैं। तो के साथAll, यह बचाता है, अद्यतन करता है, और हटाता है।

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

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 (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134

The orders were ordered by:
John Doe (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134

John Doe (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134
		
Press <ENTER> to exit...

जैसा कि आप देख सकते हैं कि हमने प्रोग्राम से कोड को हटा दिया है जो मैन्युअल रूप से कैस्केड किया गया है और हमारा एप्लिकेशन अभी भी काम कर रहा है।

इसलिए अपने रिश्ते के आधार पर, आप उन लोगों से बचना चाह सकते हैं। अब, चलो एक अलग कैस्केड संबंध पर एक नज़र डालते हैं। आओ चलते हैंOrder.hbm.xml फ़ाइल और हम उस कई-से-एक रिश्ते को कैस्केड कर सकते हैं।

<?xml version = "1.0" encoding = "utf-8" ?> 
<hibernate-mapping xmlns = "urn:nhibernate-mapping-2.2" assembly = "NHibernateDemo"
   namespace = "NHibernateDemo"> 
   
   <class name = "Order" table = "`Order`"> 
	
      <id name = "Id"> 
         <generator class = "guid.comb"/> 
      </id> 

      <property name = "Ordered"/> 
      <property name = "Shipped"/> 
      
      <component name = "ShipTo"> 
         <property name = "Street"/> 
         <property name = "City"/> 
         <property name = "Province"/> 
         <property name = "Country"/> 
      </component> 
      
      <many-to-one name = "Customer" column = "CustomerId" cascade = "save-update"/>
		
   </class> 
</hibernate-mapping>

इसलिए यदि हम एक नया आदेश बनाते हैं और इससे जुड़ा एक नया ग्राहक होता है और हम कहते हैं, उस आदेश को बचाएं, तो हम इसे समझना चाहते हैं। लेकिन एक बात जो हम शायद नहीं करना चाहते हैं वह यह है कि यदि संबंधित ग्राहक को हटाने के लिए कोई ऑर्डर हटा दिया जाता है।

इसलिए यहां, हम एक सेव अपडेट करना चाहते हैं, इसलिए एक सेव-अपडेट का उपयोग करते हुए, यह उस ग्राहक को किसी भी बचत या अपडेट को कैस्केड करेगा। इसलिए, यदि हमें एक नया ग्राहक मिलता है या यदि हम ग्राहक को बदल रहे हैं, तो यह उस पर रोक लगाएगा। यदि यह डिलीट है, तो यह डेटाबेस से डिलीट नहीं होगा।

इसलिए हमारे एप्लिकेशन को फिर से चलाना, सब कुछ अभी भी उम्मीद के मुताबिक काम करता है।

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:
      Id: 00000000-0000-0000-0000-000000000000
      Order Id: 00000000-0000-0000-0000-000000000000

Reloaded:
John Doe (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134

The orders were ordered by:
John Doe (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134
      John Doe (10b2a3d7-7fcf-483c-b1da-a5bb00b8512e)
		
   Points: 100
   HasGoldStatus: True
   MemberSince: 1/1/2012 12:00:00 AM (Utc)
   CreditRating: Good
   AverageRating: 42.4242

   Orders:
      Order Id: e6680e30-5b3b-4efa-b017-a5bb00b85133
      Order Id: b03858e7-8c36-4555-8878-a5bb00b85134
		
Press <ENTER> to exit...

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