NHibernate - कॉन्फ़िगरेशन

इस अध्याय में, हम NHibernate विन्यास को देखेंगे। हमारे पास अलग-अलग तरीके हैं जिससे हम NHibernate को कॉन्फ़िगर कर सकते हैं। यह दो मुख्य समूहों में विभाजित है

  • XML- आधारित कॉन्फ़िगरेशन
  • कोड-आधारित कॉन्फ़िगरेशन

कोड-आधारित कॉन्फ़िगरेशन

कोड-आधारित कॉन्फ़िगरेशन NHibernate में बनाया गया है। यह NHibernate 3 के आसपास पेश किया गया था और हमने अब तक कोड बेस कॉन्फ़िगरेशन का उपयोग किया है।

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>(); 
   x.LogSqlInConsole = true; 
}); 

cfg.AddAssembly(Assembly.GetExecutingAssembly());

सभी कॉन्फ़िगरेशन C # कोड में निर्दिष्ट हैं। आप यहां देख सकते हैं कि हमें हमारी नई कॉन्फ़िगरेशन ऑब्जेक्ट मिल गई है, और फिर हम उपयोग करते हैंloquacious configurationडेटाबेस को कॉन्फ़िगर करने के लिए NHibernate 3.1 के साथ पेश किया गया था। हम किस कनेक्शन स्ट्रिंग का उपयोग कर रहे हैं, हम किस डेटाबेस से जुड़ रहे हैं और उपयोग करने के लिए बोली। हम यहां अपनी मैपिंग असेंबली को भी सीधे जोड़ते हैं।

XML- आधारित कॉन्फ़िगरेशन

यदि आप XML- आधारित कॉन्फ़िगरेशन का उपयोग कर रहे हैं, तो आप एक का उपयोग कर सकते हैं hibernate.cfg.xml फ़ाइल, जो NHibernate स्कीमा का उपयोग करके सिर्फ एक स्टैंडअलोन xml फ़ाइल है, या आप अपने ऐप के अंदर उस NHibernate विशिष्ट कॉन्फ़िगरेशन को एम्बेड कर सकते हैं या web.cfg। Hibernate.cfg.xml नाम डिफ़ॉल्ट रूप से है, लेकिन हम उस xml फ़ाइल के लिए भी एक मनमाना नाम का उपयोग कर सकते हैं।

चलिए NHibernateDemoApp प्रोजेक्ट में नई xml फ़ाइल जोड़कर XML- आधारित कॉन्फ़िगरेशन पर एक नज़र डालते हैं और इसे hibernate.cfg.xml कहते हैं।

निम्नलिखित जानकारी को hibernate.cfg.xml फ़ाइल में दर्ज करें।

<?xml version = "1.0" encoding = "utf-8" ?> 
<hibernate-configuration xmlns = "urn:nhibernate-configuration-2.2"> 
   <session-factory> 
   
      <property name = "connection.connection_string">
         Data Source = asia13797\\sqlexpress;
         Initial Catalog = NHibernateDemoDB;
         Integrated Security = True;
         Connect Timeout = 15;
         Encrypt = False;
         TrustServerCertificate = False;
         ApplicationIntent = ReadWrite;
         MultiSubnetFailover = False;
      </property> 
      
      <property name = "connection.driver_class">
         NHibernate.Driver.SqlClientDriver
      </property> 
		
      <property name = "dialect">
         NHibernate.Dialect.MsSql2008Dialect
      </property> 
		
      <mapping assembly = "NHibernateDemoApp"/>
		
   </session-factory> 
	
</hibernate-configuration>

जैसा कि आप उपरोक्त xml फ़ाइल में देख सकते हैं, हमने उसी कॉन्फ़िगरेशन को निर्दिष्ट किया है जैसा कि C # में बताया गया है।

अब हम इस कॉन्फ़िगरेशन पर Program.cs फ़ाइल से टिप्पणी करते हैं और बस कॉल करते हैं Configure() विधि, जो लोड होगा hibernate.cfg.xml नीचे दिखाए अनुसार।

using HibernatingRhinos.Profiler.Appender.NHibernate; 
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) { 
		
         NHibernateProfiler.Initialize(); 
         var cfg = new Configuration(); 
         
         //cfg.DataBaseIntegration(x =>
         
         //{ 
            // x.ConnectionString = "Data Source = asia13797;\\sqlexpress
            Initial Catalog = NHibernateDemoDB;
            Integrated Security = True;
            Connect Timeout = 15;
            Encrypt =False;
            TrustServerCertificate = False;
            ApplicationIntent = ReadWrite;
            MultiSubnetFailover = False"; 
            
            // x.Driver<SqlClientDriver>(); 
            // x.Dialect<MsSql2008Dialect>(); 
            // x.LogSqlInConsole = true; 
         //}); 
         
         //cfg.AddAssembly(Assembly.GetExecutingAssembly());
			
         cfg.Configure();
         var sefact = cfg.BuildSessionFactory();
			
         using (var session = sefact.OpenSession()) { 
            
            using (var tx = session.BeginTransaction()) { 
               var students = session.CreateCriteria<Student>().List<Student>(); 
               Console.WriteLine("\nFetch the complete list again\n"); 
               
               foreach (var student in students) { 
                  Console.WriteLine("{0} \t{1} \t{2} \t{3}", student.ID,
                     student.FirstName, student.LastName, student.AcademicStanding); 
               } 
					
               tx.Commit(); 
            } 
				
            Console.ReadLine(); 
         } 
      } 
   } 
}

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

Fetch the complete list again

1 Allan Bommer Excellent
2 Jerry Lewis Good