NHibernate - मूल CRUD संचालन

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

डेटा बनाएँ

जैसा कि आप देख सकते हैं कि हमारे छात्र तालिका में कोई डेटा नहीं है NHibernateDemoDB डेटाबेस।

इसलिए कुछ डेटा जोड़ने के लिए, हमें प्रदर्शन करने की आवश्यकता है Add/Create ऑपरेशन के रूप में नीचे दिखाया गया है।

using (var session = sefact.OpenSession()) { 

   using (var tx = session.BeginTransaction()) { 
     
      var student1 = new Student { 
         ID = 1, 
         FirstMidName = "Allan", 
         LastName = "Bommer" 
      }; 
      
      var student2 = new Student { 
         ID = 2, 
         FirstMidName = "Jerry", 
         LastName = "Lewis" 
      }; 
      
      session.Save(student1); 
      session.Save(student2); 
      tx.Commit(); 
   } 
   
   Console.ReadLine(); 
}

जैसा कि आप देख सकते हैं कि हमने दो छात्रों को बनाया है और फिर सेव () विधि को कॉल करें OpenSession और फिर कमिट () का कॉल करें BeginTransaction। यहाँ पूर्ण कार्यान्वयन हैProgram.cs फ़ाइल

using NHibernate.Cfg; 
using NHibernate.Dialect; 
using NHibernate.Driver; 

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

namespace NHibernateDemoApp { 
   
   class Program { 
      
      static void Main(string[] args) { 
         var cfg = new Configuration();
			
         String Data Source = asia13797\\sqlexpress;
         String Initial Catalog = NHibernateDemoDB;
         String Integrated Security = True;
         String Connect Timeout = 15;
         String Encrypt = False;
         String TrustServerCertificate = False;
         String ApplicationIntent = ReadWrite;
         String MultiSubnetFailover = False;
			
         cfg.DataBaseIntegration(x = > { x.ConnectionString = "Data Source + 
            Initial Catalog + Integrated Security + Connect Timeout + Encrypt +
            TrustServerCertificate + ApplicationIntent + MultiSubnetFailover"; 

            x.Driver<SqlClientDriver>(); 
            x.Dialect<MsSql2008Dialect>(); 
         }); 
   
         cfg.AddAssembly(Assembly.GetExecutingAssembly()); 
         var sefact = cfg.BuildSessionFactory(); 
			
         using (var session = sefact.OpenSession()) { 
			
            using (var tx = session.BeginTransaction()) { 
               
               var student1 = new Student { 
                  ID = 1,  
                  FirstMidName = "Allan", 
                  LastName = "Bommer" 
               }; 

               var student2 = new Student { 
                  ID = 2, 
                  FirstMidName = "Jerry", 
                  LastName = "Lewis" 
               }; 
            
               session.Save(student1); 
               session.Save(student2); 
               tx.Commit();
            } 
            
            Console.ReadLine(); 
         } 
      } 
   } 
}

अब इस एप्लिकेशन को चलाते हैं और फिर SQL सर्वर ऑब्जेक्ट एक्सप्लोरर में जाते हैं और अपने डेटाबेस को रीफ्रेश करते हैं। आप देखेंगे कि उपरोक्त दो छात्र अब NHibernateDemoDB डेटाबेस में छात्र तालिका में जोड़ दिए गए हैं।

स्टूडेंट टेबल से डेटा पढ़ें

आप देख सकते हैं कि अब हमारे छात्र तालिका में दो रिकॉर्ड हैं। तालिका से इन अभिलेखों को पढ़ने के लिए, हमें कॉल करने की आवश्यकता हैCreateCriteria() निम्न कोड में दिखाया गया है।

using (var session = sefact.OpenSession()) { 
   
   using (var tx = session.BeginTransaction()) { 
      var students = session.CreateCriteria<Student>().List<Student>(); 
      
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", 
            student.ID,student.FirstMidName, student.LastName); 
      } 
      
      tx.Commit(); 
   } 
   
   Console.ReadLine(); 
}

इसलिए यदि आप रिकॉर्ड की सूची चाहते हैं तो हम केवल छात्र प्रकार की सूची कह सकते हैं।

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

1 Allan Bommer
2 Jerry Lewis

आप आईडी में निर्दिष्ट करके किसी भी रिकॉर्ड को पुनः प्राप्त कर सकते हैं Get() निम्नलिखित कोड का उपयोग करके OpenSession की विधि।

using (var session = sefact.OpenSession()) { 
   
   using (var tx = session.BeginTransaction()) { 
      var students = session.CreateCriteria<Student>().List<Student>(); 
      
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", student.ID, 
            student.FirstMidName, student.LastName); 
      }
      
      var stdnt = session.Get<Student>(1); 
      Console.WriteLine("Retrieved by ID"); 
      Console.WriteLine("{0} \t{1} \t{2}", stdnt.ID, 
         stdnt.FirstMidName, stdnt.LastName); 
      tx.Commit();
   } 
	
   Console.ReadLine(); 
}

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

1 Allan Bommer
2 Jerry Lewis
Retrieved by ID
1 Allan Bommer

अद्यतन रिकॉर्ड

तालिका में रिकॉर्ड अपडेट करने के लिए, हमें पहले उस विशेष रिकॉर्ड को प्राप्त करना होगा और फिर कॉल करके उस रिकॉर्ड को अपडेट करना होगा Update() OpenSession की विधि निम्न कोड में दिखाया गया है।

using (var session = sefact.OpenSession()) { 

   using (var tx = session.BeginTransaction()) { 
      var students = session.CreateCriteria<Student>().List<Student>(); 
     
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", student.ID, 
            student.FirstMidName, student.LastName); 
      }
      
      var stdnt = session.Get<Student>(1); 
      Console.WriteLine("Retrieved by ID"); 
      Console.WriteLine("{0} \t{1} \t{2}", stdnt.ID, stdnt.FirstMidName, stdnt.LastName);
      
      Console.WriteLine("Update the last name of ID = {0}", stdnt.ID); 
      stdnt.LastName = "Donald"; 
      session.Update(stdnt); 
      Console.WriteLine("\nFetch the complete list again\n"); 
      
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", student.ID, 
            student.FirstMidName, student.LastName); 
      } 
      
      tx.Commit();
   } 
   
   Console.ReadLine();
}

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

1 Allan Bommer
2 Jerry Lewis
Retrieved by ID
1 Allan Bommer
Update the last name of ID = 1
Fetch the complete list again
1 Allan Donald
2 Jerry Lewis

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

रिकॉर्ड हटाएं

तालिका से किसी भी रिकॉर्ड को हटाने के लिए, हमें पहले उस विशेष रिकॉर्ड को प्राप्त करना होगा और फिर कॉल करके उस रिकॉर्ड को हटाना होगा Delete() OpenSession की विधि निम्न कोड में दिखाया गया है।

using (var session = sefact.OpenSession()) { 
   
   using (var tx = session.BeginTransaction()) { 
      var students = session.CreateCriteria<Student>().List<Student>();
      
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", student.ID, 
            student.FirstMidName, student.LastName); 
      }
      
      var stdnt = session.Get<Student>(1); 
      Console.WriteLine("Retrieved by ID"); 
      Console.WriteLine("{0} \t{1} \t{2}", stdnt.ID, stdnt.FirstMidName, stdnt.LastName);
      
      Console.WriteLine("Delete the record which has ID = {0}", stdnt.ID); 
      session.Delete(stdnt);
      Console.WriteLine("\nFetch the complete list again\n"); 
      
      foreach (var student in students) { 
         Console.WriteLine("{0} \t{1} \t{2}", student.ID, student.FirstMidName, 
            student.LastName); 
      } 
      
      tx.Commit();
   } 
	
   Console.ReadLine(); 
}

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

1 Allan Donald
2 Jerry Lewis
Retrieved by ID
1 Allan Bommer
Delete the record which has ID = 1
Fetch the complete list again
2 Jerry Lewis

जैसा कि आप देख सकते हैं कि जो रिकॉर्ड 1 के बराबर आईडी है वह अब डेटाबेस में उपलब्ध नहीं है। आप SQL सर्वर ऑब्जेक्ट एक्सप्लोरर में डेटाबेस भी देख सकते हैं।