NHibernate - प्रारंभ करना
इस अध्याय में, हम एनएचबर्नेट का उपयोग करके एक सरल उदाहरण शुरू करने का तरीका देखेंगे। हम एक निर्माण करेंगेsimple console application। कंसोल एप्लिकेशन बनाने के लिए, हम विज़ुअल स्टूडियो 2015 का उपयोग करेंगे, जिसमें आपके द्वारा बनाई गई सभी विशेषताओं में NHibernate पैकेज का उपयोग करके अपने एप्लिकेशन का परीक्षण करना शामिल है।
विज़ुअल स्टूडियो में उपलब्ध प्रोजेक्ट टेम्प्लेट का उपयोग करके प्रोजेक्ट बनाने के लिए निम्नलिखित चरण हैं।
Step 1 - विज़ुअल स्टूडियो खोलें और फ़ाइल → नया → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।
Step 2 - एक नया प्रोजेक्ट डायलॉग खुलता है।
Step 3 - बाएं फलक से, टेम्प्लेट्स → विज़ुअल सी # → विंडोज चुनें।
Step 4 - मध्य फलक में, कंसोल एप्लिकेशन चुनें।
Step 5 - नाम फ़ील्ड में प्रोजेक्ट नाम, 'NHibernateDemoApp' दर्ज करें और जारी रखने के लिए ठीक क्लिक करें।
Step 6 - विजुअल स्टूडियो द्वारा प्रोजेक्ट तैयार किए जाने के बाद, आपको समाधान एक्सप्लोरर विंडो में प्रदर्शित कई फाइलें दिखाई देंगी।
जैसा कि आप जानते हैं कि हमने एक सरल कंसोल एप्लिकेशन प्रोजेक्ट बनाया है, अब हमें एनबीबर्नेट पैकेज को अपने कंसोल प्रोजेक्ट में शामिल करने की आवश्यकता है।
टूल्स मेनू पर जाएं और NuGet Package Manager → पैकेज मैनेजर कंसोल का चयन करें, यह पैकेज मैनेजर कंसोल विंडो खोलेगा।
ऊपर दिखाए गए कमांड को निर्दिष्ट करें Package Manager Consoleविंडो और प्रेस दर्ज करें, यह सभी NHibernate निर्भरताओं को डाउनलोड करेगा और सभी आवश्यक विधानसभाओं के संदर्भ बनाएगा। एक बार इंस्टॉलेशन समाप्त होने के बाद, आपको निम्न छवि में दिखाया गया संदेश दिखाई देगा।
अब जब हमने NHibernate जोड़ा है, तो अब हम कार्यान्वयन शुरू कर सकते हैं। इसलिए, हम एक बहुत ही सरल मैपिंग करके शुरुआत करने जा रहे हैंtable बुलाया Student, जिसमें बस एक पूर्णांक प्राथमिक कुंजी होती है जिसे ID और FirstName और LastName कॉलम कहा जाता है।
हमें इस छात्र का प्रतिनिधित्व करने के लिए एक वर्ग की आवश्यकता है, तो चलो समाधान एक्सप्लोरर में प्रोजेक्ट पर राइट क्लिक करके एक नया वर्ग बनाएं, जिसे छात्र जोड़ें और फिर Add → Class चुनें, जो Add New Item डायलॉग बॉक्स को खोलेगा।
दर्ज Student.csनाम फ़ील्ड में, बटन जोड़ें पर क्लिक करें। इस छात्र वर्ग में, हमारे पास अपनी पूर्णांक प्राथमिक कुंजी होनी चाहिए जिसे ID कहा जाता है, और हमें यह स्ट्रिंग बनाने की आवश्यकता है,FirstName तथा LastName छात्र वर्ग के पूर्ण कार्यान्वयन में दिखाए गए अनुसार फ़ील्ड।
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 FirstMidName { get; set; }
}
}
NHibernate एप्लिकेशन में मॉडल के साथ काम करते समय, अपने सभी क्षेत्रों को आभासी बनाना सबसे आसान है। तो यह हमारा सरल NHibernate मॉडल है जिसका हम उपयोग करेंगे और इसे बैक एंड डेटाबेस में मैप करेंगे।
अब प्रोग्राम क्लास में मेन मेथड पर चलते हैं और एक नया NHibernate कॉन्फ़िगरेशन ऑब्जेक्ट बनाते हैं।
पहली चीज जो हमें प्रदान करने की आवश्यकता है वह है connection string। यह एक डेटाबेस विशिष्ट कनेक्शन स्ट्रिंग है और कनेक्शन स्ट्रिंग को खोजने का सबसे आसान तरीका यह है कि डेटाबेस में राइट क्लिक करेंSQL Server Object Explorer और गुण चुनें।
यह गुण विंडो खोल देगा, अब नीचे स्क्रॉल करें और आपको गुण विंडो में कनेक्शन स्ट्रिंग फ़ील्ड दिखाई देगा।
कनेक्शन स्ट्रिंग की प्रतिलिपि बनाएँ और अपने कोड में निर्दिष्ट करें। निम्नलिखित मुख्य विधि का कार्यान्वयन है जिसमें हमें 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) {
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()) {
//perform database logic
tx.Commit();
}
Console.ReadLine();
}
}
}
}
कनेक्शन स्ट्रिंग के बाद, हमें एक ड्राइवर की आपूर्ति करने की आवश्यकता है, जो कि है SQLClientDriver और फिर हमें इसे एक बोली भी प्रदान करने की आवश्यकता है, जो SQL सर्वर का संस्करण है, और हम MS SQL 2008 का उपयोग करने जा रहे हैं।
NHibernate अब जानता है कि डेटाबेस से कैसे जुड़ा जाए। दूसरी चीज़ जो हमें करने की ज़रूरत है वह यह है कि हम उन मॉडलों की सूची प्रदान करें जिन्हें हम मैप करेंगे।
हम एक विधानसभा को जोड़कर ऐसा कर सकते हैं, इसलिए निर्दिष्ट करके Assembly.GetExecutingAssemblyऔर यह वह जगह है जहाँ प्रोग्राम मैपिंग फ़ाइलों को ढूँढेगा। मैपिंग फाइलें NHibernate को बताती हैं कि डेटाबेस टेबल में C # क्लासेस से कैसे जाएं।
SessionFactory NHibernate को शुरू करने के लिए आवश्यक सभी मेटाडेटा को संकलित करता है। सत्र निर्माण के लिए SessionFactory का उपयोग किया जा सकता है, जो डेटाबेस कनेक्शन के लगभग अनुरूप हैं। इसलिए उपयुक्त तरीका यह है कि इसका उपयोग ब्लॉक में किया जाए। मैं कह सकता हूंvar session बराबरी sessionFactory.OpenSession और मैं इसके लेनदेन के अंदर यह करना चाहता हूं।
एक बार सत्र खुलने के बाद, हम सत्र को एक नया लेनदेन शुरू करने के लिए कह सकते हैं और फिर हम यहां कुछ तर्क दे सकते हैं। इसलिए कुछ डेटाबेस लॉजिक करें और अंत में उस लेनदेन को करें।