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 है।