NHibernate - धाराप्रवाह हाइबरनेट

इस अध्याय में, हम धाराप्रवाह NHibernate को कवर करेंगे। धाराप्रवाह NHibernate मैपिंग का एक और तरीका है या आप कह सकते हैं कि यह NHibernate की मानक XML मैपिंग फ़ाइलों का एक विकल्प है। बजाय XML लिखने के(.hbm.xml files)दस्तावेजों। धाराप्रवाह NHibernate की मदद से, आप दृढ़ता से टाइप किए गए C # कोड में मैपिंग लिख सकते हैं।

  • धाराप्रवाह में NHibernate मैपिंग को आपके बाकी एप्लिकेशन के साथ संकलित किया जाता है।

  • आप अपने एप्लिकेशन कोड की तरह आसानी से अपने मैपिंग को बदल सकते हैं और कंपाइलर किसी भी टाइपोस पर विफल हो जाएगा।

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

  • आप यह भी निर्धारित कर सकते हैं कि चीजों को एक बार कैसे नाम दिया जाना चाहिए, फिर फ्लुएंट एनएचबेरनेट बाकी काम करता है।

नए कंसोल प्रोजेक्ट बनाकर एक सरल उदाहरण पर नजर डालते हैं। इस अध्याय में, हम एक सरल डेटाबेस का उपयोग करेंगे जिसमें हमारे पास एक सरल ग्राहक तालिका है जैसा कि निम्नलिखित छवि में दिखाया गया है।

धाराप्रवाह NHibernate स्थापित करें

धाराप्रवाह NHibernate शुरू करने के लिए पहला कदम धाराप्रवाह NHibernate पैकेज स्थापित करना है। तो खोलिएNuGet Package Manager Console और निम्न कमांड दर्ज करें।

PM> install-package FluentNHibernate

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

चलो ग्राहक का एक साधारण मॉडल वर्ग जोड़ते हैं और निम्नलिखित कार्यक्रम ग्राहक वर्ग कार्यान्वयन को दर्शाता है।

using System; 
using System.Collections.Generic; 
using System.Linq;
using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class Customer { 
      public virtual int Id { get; set; } 
      public virtual string FirstName { get; set; } 
      public virtual string LastName { get; set; } 
   } 
}

अब हमें धाराप्रवाह NHibernate का उपयोग करके मैपिंग बनाने की आवश्यकता है, इसलिए एक और वर्ग जोड़ें CustomerMapअपने प्रोजेक्ट में यहाँ CustomerMap वर्ग का कार्यान्वयन है।

using FluentNHibernate.Mapping; 
using System; 
using System.Collections.Generic; 
using System.Linq; using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class CustomerMap : ClassMap<Customer> { 
      public CustomerMap() { 
         Id(x => x.Id); 
         Map(x => x.FirstName); 
         Map(x => x.LastName); 
         Table("Customer"); 
      } 
   }
}

एक और वर्ग जोड़ते हैं NHibernateHelper जिसमें हम अलग-अलग कॉन्फ़िगरेशन सेटिंग्स सेट करेंगे।

using FluentNHibernate.Cfg; 
using FluentNHibernate.Cfg.Db; 
using NHibernate; 
using NHibernate.Tool.hbm2ddl;

namespace FluentNHibernateDemo { 

   public class NHibernateHelper { 
	
      private static ISessionFactory _sessionFactory;
		
      private static ISessionFactory SessionFactory { 
         get { 
            if (_sessionFactory == null)
            InitializeSessionFactory(); return _sessionFactory; 
         } 
      }
   
      private static void InitializeSessionFactory() { 
         _sessionFactory = Fluently.Configure() 
			
         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;
			
         .Database(MsSqlConfiguration.MsSql2008 .ConnectionString( 
            @"Data Source + Initial Catalog + Integrated Security + Connect Timeout
            + Encrypt + TrustServerCertificate + ApplicationIntent + 
            MultiSubnetFailover") .ShowSql() ) 
				
         .Mappings(m => m.FluentMappings
         .AddFromAssemblyOf<Program>()) 
         .ExposeConfiguration(cfg => new SchemaExport(cfg) 
         .Create(true, true)) 
         .BuildSessionFactory(); 
      }
		
      public static ISession OpenSession() { 
         return SessionFactory.OpenSession(); 
      } 
   }
}

अब चलते हैं Program.cs वह फ़ाइल जिसमें हम एक सत्र शुरू करेंगे और फिर एक नया ग्राहक बनाएंगे और नीचे दिखाए गए अनुसार उस ग्राहक को डेटाबेस में सहेजेंगे।

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks;

namespace FluentNHibernateDemo { 
   class Program { 
	
      static void Main(string[] args) { 
		
         using (var session = NHibernateHelper.OpenSession()) { 
			
            using (var transaction = session.BeginTransaction()) { 
               var customer = new Customer { 
                  FirstName = "Allan", 
                  LastName = "Bomer" 
               }; 
					
               session.Save(customer); 
               transaction.Commit();
               Console.WriteLine("Customer Created: " + customer.FirstName + "\t" +
                  customer.LastName); 
            } 
				
            Console.ReadKey(); 
         } 
      } 
   } 
}

आइए अपना एप्लिकेशन चलाएं और आपको निम्न आउटपुट दिखाई देगा।

if exists (select * from dbo.sysobjects where id = object_id(N'Customer') and
   OBJECTPROPERTY(id, N'IsUserTable') = 1) drop table Customer

create table Customer (
   Id INT IDENTITY NOT NULL,
   FirstName NVARCHAR(255) null,
   LastName NVARCHAR(255) null,
   primary key (Id)
)

NHibernate: INSERT INTO Customer (FirstName, LastName) VALUES (@p0, @p1); 
   select SCOPE_IDENTITY();@p0 = 'Allan' [Type: String (4000)], 
   @p1 = 'Bomer' [Type: String (4000)]
   Customer Created: Allan Bomer

जैसा कि आप देख सकते हैं कि नया ग्राहक बनाया गया है। ग्राहक रिकॉर्ड देखने के लिए, डेटाबेस पर जाएं और डेटा देखें और आप देखेंगे कि 1 ग्राहक जोड़ा गया है।