NHibernate - ORM
इससे पहले कि हम वास्तव में NHibernate का उपयोग करना शुरू कर सकें, हमें उस नींव को समझना होगा जिस पर यह बनाया गया है। NHibernate एक दृढ़ता तकनीक है जो ऑब्जेक्ट रिलेशनल मैपिंग या ORM के विचार पर आधारित है।
ORM क्या है?
ऑब्जेक्ट-रिलेशनल मैपिंग (ORM) एक है programming techniqueऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग भाषाओं में असंगत प्रकार सिस्टम के बीच डेटा परिवर्तित करने के लिए। दूसरे शब्दों में, यह एक एप्लिकेशन की व्यावसायिक वस्तुओं को संबंधपरक डेटाबेस तालिकाओं पर मैप करने की अवधारणा है, ताकि डेटा को आसानी से एक्सेस किया जा सके और किसी एप्लिकेशन के ऑब्जेक्ट मॉडल के माध्यम से पूरी तरह से अपडेट किया जा सके।
जैसा कि आप पहले से ही जानते हैं कि रिलेशनल डेटाबेस डेटा संग्रहीत करने का एक अच्छा साधन प्रदान करते हैं, जबकि ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग जटिल अनुप्रयोगों के निर्माण के लिए एक अच्छा तरीका है।
NHibernate और ORM सामान्य रूप से nontrivial व्यापार तर्क, डोमेन मॉडल और डेटाबेस के कुछ प्रकार के अनुप्रयोगों के लिए सबसे अधिक प्रासंगिक हैं।
ओआरएम के साथ, एक अनुवाद परत बनाना बहुत आसान है जो वस्तुओं को आसानी से संबंधपरक डेटा में बदल सकता है और फिर से वापस कर सकता है।
संक्षिप्त नाम ORM का अर्थ ऑब्जेक्ट रोल मॉडलिंग भी हो सकता है और ऑब्जेक्ट / रिलेशनल मैपिंग प्रासंगिक होने से पहले इस शब्द का आविष्कार किया गया था।
यह डेटाबेस मॉडलिंग में उपयोग किए जाने वाले सूचना विश्लेषण के लिए एक विधि का वर्णन करता है।
ओआरएम क्यों?
ORM एक है framework यह आपको ऑब्जेक्ट ओरिएंटेड भाषाओं में पाए जाने वाले ऑब्जेक्ट्स की दुनिया को मैप करने में सक्षम बनाता है जो रिलेशनल डेटाबेस में पाए जाने वाले रिलेशनल टेबल में पंक्तियों के लिए है
इस अवधारणा को समझने के लिए, आइए निम्नलिखित चित्र पर एक नज़र डालें।
ऊपर दिए गए आरेख में, आप देख सकते हैं कि हमारे पास दाईं ओर कर्मचारी नामक एक तालिका है जिसमें एक व्यक्तिगत कर्मचारी के साथ जुड़े डेटा के प्रत्येक टुकड़े के साथ कॉलम हैं।
हमारे पास एक आईडी के लिए एक कॉलम है जो विशिष्ट रूप से प्रत्येक कर्मचारी की पहचान करता है।
कर्मचारी के नाम के लिए एक कॉलम, उनके शामिल होने की तारीख के लिए एक और कॉलम, और अंत में एक कॉलम जिसमें एक कर्मचारी की उम्र होती है।
यदि हम किसी नए कर्मचारी को तालिकाओं में संग्रहीत करने के लिए कुछ कोड लिखना चाहते हैं, तो यह इतना आसान नहीं है।
उपरोक्त आरेख में, आप यह भी देख सकते हैं कि हमारे पास एक कर्मचारी ऑब्जेक्ट है जिसमें आईडी, नाम, दिनांक और आयु शामिल करने के लिए फ़ील्ड हैं।
ओआरएम के बिना हमें इस ऑब्जेक्ट को कुछ अलग एसक्यूएल बयानों में अनुवाद करना होगा जो कर्मचारी डेटा को कर्मचारी तालिका में सम्मिलित करेगा।
तो उपरोक्त परिदृश्य को करने के लिए SQL बनाने के लिए कोड लिखना उतना कठिन नहीं है, लेकिन यह थोड़ा थकाऊ है और गलत होने के लिए बहुत आसान है।
NHibernate जैसे ORM का उपयोग करके, हम घोषणा कर सकते हैं कि कैसे कुछ वर्गों को संबंधपरक तालिकाओं के लिए मैप किया जाना चाहिए और ORM या NHibernate को हमारे कर्मचारी तालिका में क्वेरी डेटा में SQL सम्मिलित करने, अद्यतन करने, हटाने के लिए बनाने का बुरा काम करना चाहिए।
यह हमें वस्तुओं का उपयोग करने पर अपना कोड केंद्रित रखने की अनुमति देता है और उन वस्तुओं का स्वचालित रूप से संबंधपरक तालिकाओं में अनुवाद होता है।
तो वास्तव में ओआरएम क्या करता है, यह हमें ऑब्जेक्ट को मैन्युअल रूप से टेबल पर मैप करने से बचाता है।