छोड़कर सामग्री पर जाएँ
Read this post in: de_DEen_USes_ESfr_FRhi_INid_IDjapl_PLpt_PTru_RUvizh_CNzh_TW
Home » Data Modeling / Database » उदाहरणों के साथ डेटाबेस नॉर्मलाइजेशन का व्यापक गाइड

उदाहरणों के साथ डेटाबेस नॉर्मलाइजेशन का व्यापक गाइड

परिचय

डेटाबेस नॉर्मलाइजेशन डेटाबेस प्रबंधन की दुनिया में एक महत्वपूर्ण अवधारणा है। यह डेटाबेस संरचना को कम डेटा अतिरेक और डेटा अखंडता में सुधार करके अनुकूलित करने की प्रक्रिया है। नॉर्मलाइजेशन डेटा को कुशलतापूर्वक व्यवस्थित करने और अपडेट अनोमाली, इन्सर्ट अनोमाली और डिलीट अनोमाली जैसी सामान्य डेटा विक्षेपणों को रोकने में मदद करने वाले नियमों और दिशानिर्देशों का संग्रह है।

इस लेख में, हम डेटाबेस नॉर्मलाइजेशन के मूल सिद्धांतों, विभिन्न नॉर्मल रूपों और प्रत्येक नॉर्मलाइजेशन स्तर को समझाने के लिए व्यावहारिक उदाहरण प्रदान करेंगे।

डेटाबेस को नॉर्मलाइज़ क्यों करें?

डेटाबेस नॉर्मलाइजेशन के विवरण में डूबने से पहले, यह समझना आवश्यक है कि इसकी आवश्यकता क्यों है। नॉर्मलाइजेशन कई लाभ प्रदान करता है:

  1. डेटा अखंडता: नॉर्मलाइजेशन अतिरेक को कम करके डेटा की सटीकता और सुसंगतता बनाए रखने में मदद करता है। जब डेटा बार-बार नहीं भंडारित होता है, तो त्रुटियों के लिए कम झुकाव होता है।
  2. कुशल भंडारण: नॉर्मलाइज्ड डेटाबेस अक्सर कम भंडारण स्थान लेते हैं क्योंकि डुप्लिकेट डेटा को कम किया जाता है। इससे भंडारण की कुल लागत कम होती है।
  3. प्रश्न अनुकूलन: नॉर्मलाइज्ड डेटाबेस में प्रश्न अधिक कुशल हो जाते हैं क्योंकि उन्हें बड़े, अनॉर्मलाइज्ड टेबल के बजाय छोटे, अच्छी तरह से संरचित टेबल तक पहुंचने की आवश्यकता होती है।
  4. लचीलापन: डेटा आवश्यकताओं या व्यापार नियमों में बदलाव को स्वीकार करने में नॉर्मलाइज्ड डेटाबेस अधिक लचीले होते हैं।

नॉर्मलाइजेशन के स्तर

डेटाबेस नॉर्मलाइजेशन को आमतौर पर कई स्तरों में बांटा जाता है, जिन्हें नॉर्मल रूप कहा जाता है। सबसे अधिक उपयोग किए जाने वाले नॉर्मल रूप हैं:

  1. पहला नॉर्मल रूप (1NF): सुनिश्चित करता है कि टेबल के प्रत्येक कॉलम में परमाणु, अविभाज्य मान हों। दोहराए जाने वाले समूह नहीं होने चाहिए, और प्रत्येक कॉलम का एक अद्वितीय नाम होना चाहिए।
  2. दूसरा नॉर्मल रूप (2NF): 1NF पर आधारित, 2NF आंशिक निर्भरता को दूर करता है। एक टेबल 2NF में होती है यदि यह 1NF में है और सभी गैर-की विशेषताएं पूर्ण प्राथमिक कुंजी पर फंक्शनल रूप से निर्भर हैं।
  3. तीसरा नॉर्मल रूप (3NF): 2NF पर आधारित, 3NF अनुक्रमिक निर्भरता को दूर करता है। एक टेबल 3NF में होती है यदि यह 2NF में है और सभी गैर-की विशेषताएं प्राथमिक कुंजी पर फंक्शनल रूप से निर्भर हैं, लेकिन अन्य गैर-की विशेषताओं पर नहीं।
  4. बॉयस-कॉड नॉर्मल रूप (BCNF): 3NF का कठोर रूप, BCNF सुनिश्चित करता है कि प्रत्येक गैर-त्रिविध फंक्शनल निर्भरता एक सुपरकुंजी है। इसका अर्थ है कि कोई आंशिक निर्भरता या अनुक्रमिक निर्भरता अनुमत नहीं है।
  5. चौथा नॉर्मल रूप (4NF): 4NF बहु-मूल्य निर्भरता के साथ निपटता है, जहां एक विशेषता दूसरी विशेषता पर निर्भर होती है लेकिन प्राथमिक कुंजी का फलन नहीं होती है।
  6. पांचवां नॉर्मल रूप (5NF) या प्रोजेक्ट-जॉइन नॉर्मल रूप (PJNF): इन रूपों का संबंध उन मामलों से है जहां एक टेबल 4NF में है, लेकिन जॉइन निर्भरताएं हैं जिन्हें आगे अनुकूलित किया जा सकता है।

अब, आइए इन नॉर्मल रूपों को उदाहरणों के साथ समझाएं:

पहला नॉर्मल रूप (1NF)

ग्राहक आदेशों को संग्रहीत करने वाली अनार्मलाइज्ड तालिका पर विचार करें:

आदेशID ग्राहक उत्पाद
1 जॉन सेब, केले, संतरे
2 एलिस अंगूर, स्ट्रॉबेरी
3 बॉब नींबू, लाइम

इस तालिका 1NF का उल्लंघन करती है क्योंकि उत्पाद कॉलम में आइटम की सूची शामिल है। 1NF तक लाने के लिए, हम उत्पादों को अलग-अलग पंक्तियों में विभाजित करते हैं:

आदेशID ग्राहक उत्पाद
1 जॉन सेब
1 जॉन केले
1 जॉन संतरे
2 एलिस अंगूर
2 एलिस स्ट्रॉबेरी
3 बॉब नींबू
3 बॉब लाइम

अब, प्रत्येक कोष्ठक में एक परमाणु मान है, और तालिका 1NF में है।

द्वितीय सामान्य रूप (2NF)

छात्रों और उनके पाठ्यक्रमों के बारे में जानकारी संग्रहीत करने वाली एक तालिका पर विचार करें:

छात्र आईडी पाठ्यक्रम आईडी पाठ्यक्रम का नाम अध्यापक
1 101 गणित प्रो. स्मिथ
1 102 भौतिकी प्रो. जॉनसन
2 101 गणित प्रो. स्मिथ
3 103 इतिहास प्रो. डेविस

इस तालिका 2NF का उल्लंघन करती है क्योंकि अध्यापक गुणधर्म दोनों पर निर्भर है छात्र आईडी और पाठ्यक्रम आईडी. 2NF प्राप्त करने के लिए, हम तालिका को दो अलग-अलग तालिकाओं में विभाजित करते हैं:

छात्र तालिका:

छात्र आईडी छात्र नाम
1 जॉन
2 एलिस
3 बॉब

पाठ्यक्रम तालिका:

पाठ्यक्रम आईडी पाठ्यक्रम नाम अध्यापक
101 गणित प्रो. स्मिथ
102 भौतिकी प्रो. जॉनसन
103 इतिहास प्रो. डेविस

अब, यह अध्यापक गुणधर्म केवल इस पर निर्भर करता है कोर्सआईडी, और तालिका 2NF में है।

तृतीय सामान्य रूप (3NF)

कर्मचारियों और उनके प्रोजेक्ट्स के बारे में जानकारी संग्रहीत करने वाली एक तालिका पर विचार करें:

कर्मचारीआईडी प्रोजेक्टआईडी प्रोजेक्टनाम प्रबंधक
1 101 प्रोजेक्टए जॉन
1 102 प्रोजेक्टबी एलिस
2 101 प्रोजेक्टए जॉन
3 103 प्रोजेक्टसी बॉब

इस तालिका 3NF का उल्लंघन करती है क्योंकि प्रबंधक लक्षण मुख्य कुंजी पर सीधे नहीं, बल्कि कर्मचारीआईडी, मुख्य कुंजी पर सीधे नहीं। 3NF तक लाने के लिए, हम तालिका को दो अलग-अलग तालिकाओं में विभाजित करते हैं:

कर्मचारी तालिका:

कर्मचारीआईडी कर्मचारीनाम
1 जॉन
2 एलिस
3 बॉब

प्रोजेक्ट तालिका:

प्रोजेक्टआईडी प्रोजेक्टनाम
101 प्रोजेक्टए
102 प्रोजेक्टबी
103 प्रोजेक्टसी

कर्मचारीप्रोजेक्ट तालिका:

कर्मचारीआईडी प्रोजेक्टआईडी
1 101
1 102
2 101
3 103

अब, द प्रबंधक लक्षण द प्रोजेक्टआईडी, और तालिका 3NF में है।

बॉयस-कॉड नॉर्मल फॉर्म (BCNF)

BCNF, 3NF का अधिक कठोर संस्करण है। BCNF को समझाने के लिए, एक तालिका पर विचार करें जो प्रोफेसरों और उनके अनुसंधान क्षेत्रों के बारे में जानकारी संग्रहित करती है:

प्रोफेसरआईडी अनुसंधान क्षेत्र कार्यालय संख्या
1 कृत्रिम बुद्धिमत्ता 101
2 मशीन लर्निंग 102
3 कृत्रिम बुद्धिमत्ता 103

इस तालिका में BCNF का उल्लंघन होता है क्योंकि अनुसंधान क्षेत्र और कार्यालय संख्या (अर्थात, कार्यालय संख्या अनुसंधान क्षेत्र पर निर्भर है)। BCNF प्राप्त करने के लिए, हम तालिका को दो अलग-अलग तालिकाओं में विभाजित करते हैं:

प्रोफेसर्स तालिका:

प्रोफेसरआईडी प्रोफेसर नाम
1 प्रो. स्मिथ
2 प्रो. जॉनसन
3 प्रो. डेविस

अनुसंधान क्षेत्रों की सारणी:

अनुसंधान क्षेत्र कार्यालय संख्या
कृत्रिम बुद्धिमत्ता 101
मशीन लर्निंग 102

प्रोफेसर अनुसंधान सारणी:

प्रोफेसर आईडी अनुसंधान क्षेत्र
1 कृत्रिम बुद्धिमत्ता
2 मशीन लर्निंग
3 कृत्रिम बुद्धिमत्ता

अब, सारणी BCNF में है क्योंकि कोई गैर-त्रिवियल फंक्शनल निर्भरता नहीं है।

चौथा सामान्य रूप (4NF)

4NF बहु-मूल्य निर्भरता के साथ निपटता है। किताबों और उनके लेखकों के बारे में जानकारी संग्रहीत करने वाली सारणी पर विचार करें:

पुस्तक आईडी शीर्षक लेखक
1 पुस्तक ए लेखकX, लेखकY
2 पुस्तकB लेखकY, लेखकZ
3 पुस्तकC लेखकX

इस तालिका का 4NF का उल्लंघन होता है क्योंकि निम्नलिखित के बीच एक बहु-मूल्य निर्भरता हैपुस्तकID और लेखक. 4NF प्राप्त करने के लिए, हम तालिका को तीन अलग-अलग तालिकाओं में विभाजित करते हैं:

पुस्तकों की तालिका:

पुस्तकID शीर्षक
1 पुस्तकA
2 पुस्तकB
3 पुस्तकC

लेखकों की तालिका:

लेखकID लेखक का नाम
1 लेखकX
2 लेखकY
3 लेखकZ

बुकआथर्स टेबल:

बुकआईडी लेखकआईडी
1 1
1 2
2 2
2 3
3 1

अब, प्रत्येक टेबल 4NF में है, और बहु-मूल्य निर्भरताएं हटा दी गई हैं।

पांचवीं सामान्य रूप (5NF) या प्रोजेक्ट-जॉइन सामान्य रूप (PJNF)

5NF या PJNF जॉइन निर्भरताओं के साथ निपटता है, जो इस परिचयात्मक लेख के दायरे से परे हैं। 5NF प्राप्त करने के लिए आमतौर पर अधिक विभाजन की आवश्यकता होती है और जटिल डेटाबेस के लिए अक्सर आवश्यक होता है।

निष्कर्ष

डेटाबेस नॉर्मलाइजेशन डेटाबेस डिजाइन में एक महत्वपूर्ण प्रक्रिया है, जिसका उद्देश्य डेटा स्टोरेज को अनुकूलित करना, डेटा अखंडता में सुधार करना और डेटा असामान्यताओं को कम करना है। नॉर्मलाइज्ड टेबल में डेटा को व्यवस्थित करके आप अपने डेटाबेस सिस्टम की दक्षता और रखरखाव में सुधार कर सकते हैं।

याद रखें कि BCNF और 4NF जैसे उच्च सामान्य रूपों को प्राप्त करना सभी डेटाबेस के लिए आवश्यक नहीं होता है। नॉर्मलाइजेशन का स्तर आपके एप्लिकेशन की विशिष्ट आवश्यकताओं और डेटा अखंडता और प्रदर्शन के बीच के व्यापार के आधार पर निर्भर करता है।

जब डेटाबेस का डिजाइन करते हैं, तो नॉर्मलाइजेशन और व्यावहारिकता के बीच संतुलन बनाना आवश्यक है। बहुत स्थितियों में, 3NF प्राप्त करना डेटा अखंडता सुनिश्चित करने और अच्छे प्रश्न प्रदर्शन को बनाए रखने के लिए पर्याप्त होता है।

नॉर्मलाइजेशन के सिद्धांतों को समझना और वास्तविक दुनिया के उदाहरणों के साथ उनका अभ्यास करना डेटाबेस प्रशासकों और विकासकर्मियों के लिए दक्ष और विश्वसनीय डेटाबेस प्रणालियों के निर्माण के लिए महत्वपूर्ण है।

प्रातिक्रिया दे