NHibernate - डेटा प्रकार मानचित्रण

इस अध्याय में, हम मानचित्रण डेटा प्रकारों को शामिल करेंगे। मानचित्रण संस्थाएं सीधी हैं, इकाई वर्ग हमेशा डेटाबेस तालिकाओं का उपयोग करके मैप किए जाते हैं<class>, <subclass>, and <joined-subclass>मानचित्रण तत्व। मूल्य प्रकारों को कुछ और चाहिए, जो कि मैपिंग प्रकारों की आवश्यकता होती है।

NHibernate विभिन्न प्रकार के डेटा मैप करने में सक्षम है। यहां सबसे आम डेटा प्रकारों की सूची दी गई है जो समर्थित हैं।

मानचित्रण प्रकार .NET प्रकार System.Data.DbType
int16 System.Int16 DbType.Int16
int32 System.Int32 DbType.Int32
Int64 System.Int64 DbType.Int64
एक System.Single DbType.Single
दोहरा System.Double DbType.Double
दशमलव System.Decimal DbType.Decimal
तार System.String DbType.String
AnsiString System.String DbType.AnsiString
बाइट System.Byte DbType.Byte
चार System.Char DbType.StringFixedLength — एक वर्ण
AnsiChar System.Char DbType.AnsiStringFixedLength - एक चरित्र
बूलियन System.Boolean DbType.Boolean
GUID System.Guid DbType.Guid
PersistentEnum System.Enum (एक गणना) अंतर्निहित मान के लिए DbType
सही गलत System.Boolean DbType.AnsiStringFixedLength- या तो 'T' या 'F'
हाँ नही System.Boolean DbType.AnsiStringFixedLength- 'Y' या 'N'
दिनांक और समय दिनांक और समय DbType.DateTime- मिलीसेकंड को अनदेखा करता है
टिक System.DateTime DbType.Int64
समय अवधि System.TimeSpan DbType.Int64
समय-चिह्न System.DateTime डेटाबेस का समर्थन करता है के रूप में DbType.DateTime- के रूप में विशिष्ट
बायनरी System.Byte [] DbType.Binary
BinaryBlob System.Byte [] DbType.Binary
StringClob System.String DbType.String
serializable किसी भी System.Object को SerializableAttribute के साथ चिह्नित किया गया DbType.Binary
CultureInfo System.Globalization.CultureInfo DbType.String- संस्कृति के लिए पाँच वर्ण
प्रकार सिस्टम प्रकार DbType.String विधानसभा में नाम रखने योग्य है

ऊपर दी गई तालिका नीचे बताए गए बिंदुओं के बारे में विस्तार से बताती है।

  • साधारण संख्यात्मक प्रकारों से तार तक सब कुछ, जिसका उपयोग करके विभिन्न तरीकों से मैप किया जा सकता है varchars, chars आदि साथ ही साथ स्ट्रिंग ब्लब्स और सभी प्रकार के प्रकार जो डेटाबेस का समर्थन करते हैं।

  • यह मैप करने में भी सक्षम है Booleans, शून्य और अपनों का उपयोग करने वाले क्षेत्रों में, चरित्र क्षेत्र जिसमें सत्य, असत्य या T और F होता है।

  • यह परिभाषित करने के तरीके की एक विस्तृत विविधता है कि डेटाबेस में पीछे के छोर, बूलियन मानों के नक्शे कैसे हैं।

  • हम मानचित्रण को संभाल सकते हैं DateTime, समय क्षेत्र ऑफसेट, दिन के उजाले बचत समय, सहित और बाहर दोनों।

  • हम भी मैप कर सकते हैं enumerations; हम इन्हें स्ट्रिंग्स या उनके अंतर्निहित संख्यात्मक मानों के लिए मैप कर सकते हैं।

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

अब छात्र वर्ग में FirstMidName को FirstName में बदलें, जहाँ हम FirstMidName कॉलम को नहीं बदलेंगे, लेकिन हम देखेंगे कि NHibernate को कैसे बताएं कि इस रूपांतरण को करना जानते हैं। निम्नलिखित अद्यतन छात्र वर्ग है।

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

namespace NHibernateDemoApp { 
  
   class Student { 
      public virtual int ID { get; set; } 
      public virtual string LastName { get; set; } 
      public virtual string FirstName { get; set; } 
   }
}

यहाँ NHibernate मैपिंग फ़ाइल का कार्यान्वयन है।

<?xml version = "1.0" encoding = "utf-8" ?> 
<hibernate-mapping xmlns = "urn:nhibernate-mapping-2.2" assembly = "NHibernateDemoApp" 
   namespace = "NHibernateDemoApp"> 
   
   <class name = "Student">
	
      <id name = "ID"> 
         <generator class = "native"/>
      </id> 
   
      <property name = "LastName"/> 
      <property name = "FirstName" column = "FirstMidName" type = "String"/> 
   </class> 

</hibernate-mapping>

इस उदाहरण में, मान लें कि FirstName फ़ील्ड .NET स्ट्रिंग है, और FirstMidName स्तंभ एक है SQL nvarchar। अब NHibernate को यह बताने के लिए कि इस रूपांतरण को कैसे अंजाम दिया जाए, इसके नाम के बराबर सेट करेंFirstName और के बराबर कॉलम FirstMidName और स्ट्रिंग के बराबर मैपिंग प्रकार निर्दिष्ट करें, जो इस विशेष रूपांतरण के लिए उपयुक्त है।

निम्नलिखित एक है Program.cs फ़ाइल कार्यान्वयन।

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(); 
			
         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()); 
         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}", student.ID, student.FirstName,
                     student.LastName); 
               } 
					
               tx.Commit(); 
            } 
				
            Console.ReadLine(); 
         } 
      } 
   }
}

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

NHibernate: SELECT this_.ID as ID0_0_, this_.LastName as LastName0_0_, 
   this_.FirstMidName as FirstMid3_0_0_ FROM Student this_

Fetch the complete list again
3 Allan Bommer
4 Jerry Lewis

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

आइए एक और उदाहरण देखें जिसमें हम छात्र वर्ग में एक और संपत्ति जोड़ेंगे enumप्रकार। यहाँ छात्र वर्ग कार्यान्वयन है।

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

namespace NHibernateDemoApp { 
   
   class Student { 
      public virtual int ID { get; set; } 
      public virtual string LastName { get; set; } 
      public virtual string FirstName { get; set; } 
      public virtual StudentAcademicStanding AcademicStanding { get; set; } 
   } 
   
   public enum StudentAcademicStanding { 
      Excellent, 
      Good, 
      Fair, 
      Poor, 
      Terrible 
   } 
}

जैसा कि आप देख सकते हैं कि एन्यूमरेशन में विभिन्न प्रकार के मूल्य होते हैं जो संभवतः इस तरह के हो सकते हैं, जैसे कि, उत्कृष्ट, अच्छा, उचित, खराब और भयानक।

मैपिंग फ़ाइल पर कूदते हुए, आप देख सकते हैं कि इनमें से प्रत्येक गुण मैपिंग फ़ाइल में नए जोड़े गए सहित सूचीबद्ध हैं AcademicStanding संपत्ति।

<?xml version = "1.0" encoding = "utf-8" ?> 
<hibernate-mapping xmlns = "urn:nhibernate-mapping-2.2" 
   assembly = "NHibernateDemoApp" namespace = "NHibernateDemoApp"> 
   
   <class name = "Student"> 
	
      <id name = "ID"> 
         <generator class = "native"/> 
      </id> 

      <property name = "LastName"/> 
      <property name = "FirstName" column = "FirstMidName" type = "String"/> 
      <property name = "AcademicStanding"/> 
   </class>  

</hibernate-mapping>

अब हमें डेटाबेस को भी बदलना होगा, इसलिए SQL सर्वर ऑब्जेक्ट एक्सप्लोरर पर जाएं और डेटाबेस पर राइट-क्लिक करें और न्यू क्वेरी ... विकल्प चुनें।

यह क्वेरी संपादक को खोलेगा और फिर नीचे दिए गए क्वेरी को निर्दिष्ट करेगा।

DROP TABLE [dbo].[Student]

CREATE TABLE [dbo].[Student] ( 
   [ID] INT IDENTITY (1, 1) NOT NULL, 
   [LastName] NVARCHAR (MAX) NULL, 
   [FirstMidName] NVARCHAR (MAX) NULL, 
   [AcademicStanding] NCHAR(10) NULL, 
   CONSTRAINT [PK_dbo.Student] PRIMARY KEY CLUSTERED ([ID] ASC) 
);

यह क्वेरी पहले मौजूदा छात्र तालिका को गिरा देगी और फिर एक नई तालिका बनाएगी।

जैसा कि ऊपर दिखाया गया है Execute आइकन पर Clcik। एक बार जब क्वेरी को सक्सेसफुल कर दिया जाता है तो आपको एक मैसेज दिखाई देता है।

डेटाबेस और तालिका ड्रॉपडाउन का विस्तार करें, और फिर छात्र तालिका पर राइट-क्लिक करें और डिज़ाइनर का चयन करें।

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

निम्नलिखित में दिखाए अनुसार दो रिकॉर्ड जोड़ते हैं Program.cs फ़ाइल।

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(); 
			
         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, 
                  FirstName = "Allan", 
                  LastName = "Bommer",
                  AcademicStanding = StudentAcademicStanding.Excellent 
               };
               
               var student2 = new Student { 
                  ID = 2, 
                  FirstName = "Jerry", 
                  LastName = "Lewis", 
                  AcademicStanding = StudentAcademicStanding.Good 
               };
					
               session.Save(student1); 
               session.Save(student2);
               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

अब स्टूडेंट टेबल पर राइट क्लिक करके डेटाबेस पर नजर डालते हैं।

डेटा देखें का चयन करें और आपको छात्र तालिका में दो रिकॉर्ड दिखाई देंगे जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

आप देख सकते हैं कि दो रिकॉर्ड जोड़े गए हैं और एलन में एकेडेमिकस्टैंडिंग 0 है और जेरी के पास एकेडेमिकस्टैंडिंग 1 है। ऐसा इसलिए है क्योंकि नेट में डिफ़ॉल्ट रूप से पहला एन्यूमरेशन वैल्यू 0 है, जो कि अगर आप देखें तो उत्कृष्ट है StudentAcademicStanding। जबकि, Student.cs फ़ाइल में गुड दूसरा है, इसलिए इसका मान 1 है।