NHibernate - लोड / प्राप्त करें

इस अध्याय में, हम यह कवर करेंगे कि कैसे लोड और गेट फीचर काम कर रहे हैं और हम उनका उपयोग कैसे कर सकते हैं। ये दो बहुत ही समान API द्वारा प्रदान किए गए हैंISession प्राथमिक कुंजी द्वारा किसी वस्तु को लोड करने के लिए।

  • Get - यह वस्तु या अशक्त लौटाएगा।

  • Load - यह वस्तु को लौटा देगा या इसे फेंक देगा ObjectNotFoundException

अब, हमारे पास ये दो अलग-अलग एपीआई क्यों हैं?

भार

  • ऐसा इसलिए है क्योंकि लोड डेटाबेस राउंड ट्रिप्स को अधिक कुशलता से ऑप्टिमाइज़ कर सकता है।

  • लोड वास्तव में एक प्रॉक्सी ऑब्जेक्ट देता है और जब आप लोड कॉल जारी करते हैं तो डेटाबेस को सही तरीके से एक्सेस करने की आवश्यकता नहीं होती है।

  • जब आप उस प्रॉक्सी का उपयोग करते हैं, तो ऑब्जेक्ट डेटाबेस में नहीं होता है, यह उस बिंदु पर ObjectNotFoundException को फेंक सकता है।

प्राप्त

  • इसके विपरीत, CLR की सीमाओं के कारण या के साथ Common Language Runtime और NHibernate को तुरंत डेटाबेस में जाना चाहिए, जांचें कि क्या वस्तुएं हैं और यदि यह मौजूद नहीं है तो वापस लौट जाएं।

  • उस भ्रूण को विलंबित करने का ऑब्जेक्ट विकल्प नहीं है, उस राउंडट्रिप को डेटाबेस में बाद के समय के लिए, क्योंकि यह एक प्रॉक्सी ऑब्जेक्ट को वापस नहीं कर सकता है और उस प्रॉक्सी ऑब्जेक्ट को एक नल के लिए बाहर निकाल दिया, जब उपयोगकर्ता वास्तव में इसे एक्सेस करता है।

आइए एक सरल उदाहरण देखें जिसमें आप देखेंगे कि ये वास्तव में कैसे उपयोग किए जाते हैं और गेट और लोड के बीच का अंतर है। हम समान डोमेन कक्षाओं के साथ जारी रखेंगेCustomers तथा Orders और इसी तरह पिछले अध्याय से एक ही मैपिंग फ़ाइलें।

इस उदाहरण में, हम पहले निम्न कार्यक्रम में दिखाए गए अनुसार का उपयोग करेंगे।

using System; 
using System.Data; 
using System.Linq; 
using System.Reflection; 

using HibernatingRhinos.Profiler.Appender.NHibernate; 
using NHibernate.Cfg; 
using NHibernate.Criterion; 
using NHibernate.Dialect; 
using NHibernate.Driver;
using NHibernate.Linq; 

namespace NHibernateDemo { 

   internal class Program { 
	
      private static void Main() { 
		
         var cfg = ConfigureNHibernate(); 
         var sessionFactory = cfg.BuildSessionFactory();
         using(var session = sessionFactory.OpenSession()) 
         
         using(var tx = session.BeginTransaction()) { 
            var id1 = Guid.Parse("4e97c816-6bce-11e1-b095-6cf049ee52be"); 
            var id2 = Guid.Parse("AAAAAAAA-BBBB-CCCC-DDDD-EEEEEEEEEEEE");
				
            var customer1 = session.Get<Customer>(id1); 
            Console.WriteLine("Customer1 data"); 
            Console.WriteLine(customer1);
				
            var customer2 = session.Get<Customer>(id2); 
            Console.WriteLine("Customer2 data"); 
            Console.WriteLine(customer2); 
				
            tx.Commit(); 
         }
			
         Console.WriteLine("Press <ENTER> to exit..."); 
         Console.ReadLine(); 
      }
		
      private static Configuration ConfigureNHibernate() {
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
         
         cfg.DataBaseIntegration(x => { 
            x.ConnectionStringName = "default"; 
            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
            x.IsolationLevel = IsolationLevel.RepeatableRead;
            x.Timeout = 10; 
            x.BatchSize = 10; 
         }); 
         
         cfg.SessionFactory().GenerateStatistics();
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         return cfg; 
      } 
   } 
}

जैसा कि आप देख सकते हैं कि हमारे पास दो हैं GuidID की, पहली वाली एक अच्छी ID है, यह एक ग्राहक की ID है जिसे हम जानते हैं कि वह डेटाबेस में है। जबकि दूसरी आईडी डेटाबेस में मौजूद नहीं है। इन दोनों आईडी को एक पैरामीटर के रूप में पास किया जाता हैGet() विधि और फिर परिणाम कंसोल पर मुद्रित होता है।

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Customer1 data
Laverne Hegmann (4e97c816-6bce-11e1-b095-6cf049ee52be)
   Points: 74
   HasGoldStatus: True
   MemberSince: 4/4/2009 12:00:00 AM (Utc)
   CreditRating: Neutral
   AverageRating: 0

Orders:
   Order Id: 4ea14d96-6bce-11e1-b095-6cf049ee52be
   Order Id: 4ea14d96-6bce-11e1-b096-6cf049ee52be
   Order Id: 4ea14d96-6bce-11e1-b097-6cf049ee52be
   Order Id: 4ea14d96-6bce-11e1-b098-6cf049ee52be
	
Customer2 data
Press <ENTER> to exit...

जैसा कि आप देख सकते हैं कि Customer1 डेटा मुद्रित है, लेकिन Customer2 डेटा खाली है, ऐसा इसलिए है क्योंकि डेटाबेस में Customer2 रिकॉर्ड उपलब्ध नहीं है।

जब आप अपना एप्लिकेशन फिर से चलाते हैं, तो हम कमिटमेंट स्टेटमेंट से पहले एक विराम बिंदु सम्मिलित कर सकते हैं और फिर वॉच विंडो में दोनों ग्राहकों को देख सकते हैं।

जैसा कि आप देख सकते हैं कि Customer1 डेटा उपलब्ध है, जबकि Customer2 शून्य है और प्रकार है NHibernateDemo.Customer दोंनो के लिए।

अब निम्न कोड में दिखाए गए उदाहरण में Get के बजाय लोड विधि का उपयोग करें।

using System; 
using System.Data; 
using System.Linq; 
using System.Reflection; 

using HibernatingRhinos.Profiler.Appender.NHibernate; 
using NHibernate.Cfg; 
using NHibernate.Criterion; 
using NHibernate.Dialect; 
using NHibernate.Driver;
using NHibernate.Linq; 

namespace NHibernateDemo { 

   internal class Program { 
	
      private static void Main() { 
		
         var cfg = ConfigureNHibernate(); 
         var sessionFactory = cfg.BuildSessionFactory();
         using(var session = sessionFactory.OpenSession()) 
         
         using(var tx = session.BeginTransaction()) { 
            var id1 = Guid.Parse("4e97c816-6bce-11e1-b095-6cf049ee52be"); 
            var id2 = Guid.Parse("AAAAAAAA-BBBB-CCCC-DDDD-EEEEEEEEEEEE");
				
            var customer1 = session.Load<Customer>(id1); 
            Console.WriteLine("Customer1 data"); 
            Console.WriteLine(customer1);
				
            var customer2 = session.Load<Customer>(id2); 
            Console.WriteLine("Customer2 data"); 
            Console.WriteLine(customer2); 
				
            tx.Commit(); 
         }
			
         Console.WriteLine("Press <ENTER> to exit..."); 
         Console.ReadLine(); 
      }
		
      private static Configuration ConfigureNHibernate() { 
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
         
         cfg.DataBaseIntegration(x => { 
            x.ConnectionStringName = "default"; 
            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
            x.IsolationLevel = IsolationLevel.RepeatableRead; 
            x.Timeout = 10;
            x.BatchSize = 10; 
         }); 
			
         cfg.SessionFactory().GenerateStatistics();
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         return cfg; 
      } 
   } 
}

अब इस उदाहरण को चलाते हैं और आप देखेंगे कि स्क्रीनशॉट में देखे गए निम्न अपवाद को फेंक दिया गया है।

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

Customer1 data
Laverne Hegmann (4e97c816-6bce-11e1-b095-6cf049ee52be)
   Points: 74
   HasGoldStatus: True
   MemberSince: 4/4/2009 12:00:00 AM (Utc)
   CreditRating: Neutral
   AverageRating: 0

   Orders:
      Order Id: 4ea14d96-6bce-11e1-b095-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b096-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b097-6cf049ee52be
      Order Id: 4ea14d96-6bce-11e1-b098-6cf049ee52be 
		
Customer2 data