Database
 sql >> डेटाबेस >  >> RDS >> Database

एक डेटाबेस में एक-से-एक संबंध क्या है?

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

डेटा मॉडलिंग में निकायों (तालिकाओं) के बीच तीन प्रकार के संबंध होते हैं:

  • एक-से-अनेक संबंध (1:M के रूप में भी निर्दिष्ट)।
  • कई-से-अनेक संबंध (एम:एन).
  • एक-से-एक संबंध (1:1)।

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

इस लेख में, हम तीसरे प्रकार के संबंधों पर चर्चा करेंगे:एक-से-एक संबंध . डेटा मॉडल में यह सबसे कम सामान्य प्रकार का संबंध है। हम एक-से-एक रिश्तों के उदाहरण देंगे, एक ईआर आरेख में एक-से-एक संबंधों के लिए संकेतन दिखाएंगे, और व्यवहार में एक-से-एक संबंधों पर चर्चा करेंगे।

एक-से-एक संबंधों के उदाहरण

सबसे पहले, एक-से-एक संबंध क्या है? यह एक ऐसा संबंध है जहां एक इकाई (तालिका) में एक रिकॉर्ड दूसरी इकाई (तालिका) में ठीक एक रिकॉर्ड से जुड़ा होता है।

आइए एक-से-एक रिश्तों के कुछ वास्तविक जीवन के उदाहरण देखें:

  • देश - राजधानी शहर :प्रत्येक देश की ठीक एक राजधानी होती है। प्रत्येक राजधानी शहर बिल्कुल एक देश की राजधानी है।
  • व्यक्ति - उनकी उंगलियों के निशान . प्रत्येक व्यक्ति के पास उंगलियों के निशान का एक अनूठा सेट होता है। उंगलियों के निशान का प्रत्येक सेट ठीक एक व्यक्ति की पहचान करता है।
  • ईमेल - उपयोगकर्ता खाता . कई वेबसाइटों के लिए, एक ईमेल पता ठीक एक उपयोगकर्ता खाते से जुड़ा होता है और प्रत्येक उपयोगकर्ता खाते की पहचान उसके ईमेल पते से होती है।
  • पति/पत्नी - पति/पत्नी :एक एकल विवाह में, प्रत्येक व्यक्ति का बिल्कुल एक जीवनसाथी होता है।
  • उपयोगकर्ता प्रोफ़ाइल - उपयोगकर्ता सेटिंग . एक उपयोगकर्ता के पास उपयोगकर्ता सेटिंग्स का एक सेट होता है। उपयोगकर्ता सेटिंग का एक सेट ठीक एक उपयोगकर्ता के साथ संबद्ध है।

स्पष्टता के लिए, आइए इन उदाहरणों की तुलना ऐसे संबंधों से करें जो एक-से-एक नहीं हैं:

  • देश - शहर: प्रत्येक शहर ठीक एक देश में है, लेकिन अधिकांश देशों में कई शहर हैं।
  • माता-पिता - बच्चे :प्रत्येक बच्चे के दो माता-पिता होते हैं, लेकिन प्रत्येक माता-पिता के कई बच्चे हो सकते हैं।
  • कर्मचारी - प्रबंधक :प्रत्येक कर्मचारी के पास ठीक एक तत्काल पर्यवेक्षक या प्रबंधक होता है, लेकिन प्रत्येक प्रबंधक आमतौर पर कई कर्मचारियों का पर्यवेक्षण करता है।

ER आरेख में एक-से-एक संबंध को प्रदर्शित करना

ईआर आरेख में एक-से-एक संबंध को सभी रिश्तों की तरह, दो संस्थाओं को जोड़ने वाली रेखा के साथ दर्शाया जाता है। "एक" कार्डिनैलिटी को एक सीधी रेखा के साथ दर्शाया गया है। ("कई" कार्डिनैलिटी को कौवा के पैर के प्रतीक के साथ दर्शाया गया है।)

देश और राजधानी के बीच आमने-सामने के रिश्ते को इस तरह दर्शाया जा सकता है:

लंबवत सीधी रेखाओं का अर्थ है “अनिवार्य " यह आरेख दिखाता है कि एक पूंजी के लिए एक देश होना अनिवार्य है और एक देश के लिए एक राजधानी होना अनिवार्य है।

एक और संभावना यह है कि रिश्ते के एक या दोनों पक्ष वैकल्पिक . हों . एक वैकल्पिक पक्ष को एक खुले सर्कल के साथ दर्शाया गया है। यह आरेख कहता है कि एक व्यक्ति और उसकी उंगलियों के निशान के बीच एक-से-एक संबंध है। एक व्यक्ति अनिवार्य है (उंगलियों के निशान एक व्यक्ति को सौंपे जाने चाहिए), लेकिन उंगलियों के निशान वैकल्पिक हैं (एक व्यक्ति के पास डेटाबेस में कोई उंगलियों के निशान नहीं हो सकते हैं)।

भौतिक डेटाबेस में आमने-सामने संबंध

भौतिक डेटाबेस में एक-से-एक संबंध लागू करने के कुछ तरीके हैं।

प्राथमिक कुंजी विदेशी कुंजी के रूप में

डेटाबेस में एक-से-एक संबंध को लागू करने का एक तरीका दोनों तालिकाओं में एक ही प्राथमिक कुंजी का उपयोग करना है। प्राथमिक कुंजी में समान मान वाली पंक्तियाँ संबंधित हैं। इस उदाहरण में, फ़्रांस एक country है id . के साथ 1 और इसकी राजधानी शहर तालिका में है capital id . के अंतर्गत 1.

country

<वें शैली="पृष्ठभूमि-रंग:#cecece">नाम
id
1 फ़्रांस
2 जर्मनी
3 स्पेन

capital

तकनीकी रूप से, प्राथमिक कुंजी में से एक को विदेशी कुंजी के रूप में चिह्नित किया जाना चाहिए, जैसे इस डेटा मॉडल में:

तालिका में प्राथमिक कुंजी capital एक विदेशी कुंजी भी है जो देश तालिका में आईडी कॉलम का संदर्भ देती है . चूंकि capital.id एक प्राथमिक कुंजी है, कॉलम में प्रत्येक मान अद्वितीय है, इसलिए पूंजी अधिकतम एक देश को संदर्भित कर सकती है। यह भी होना चाहिए किसी देश का संदर्भ लें - यह एक प्राथमिक कुंजी है, इसलिए इसे खाली नहीं छोड़ा जा सकता है।

अद्वितीय बाधा के साथ अतिरिक्त विदेशी कुंजी

डेटाबेस में एक-से-एक संबंध लागू करने का दूसरा तरीका एक नया कॉलम जोड़ना और इसे एक विदेशी कुंजी बनाना है।

इस उदाहरण में, हम country_id . कॉलम जोड़ते हैं तालिका में capital . id . के साथ राजधानी 1, मैड्रिड, देश 3, स्पेन से जुड़ा है।

country

<वें शैली="पृष्ठभूमि-रंग:#cecece">नाम
id
1 फ़्रांस
2 जर्मनी
3 स्पेन

capital

<वें शैली="पृष्ठभूमि-रंग:#cecece">नाम <वें शैली ="पृष्ठभूमि-रंग:#cecece">देश_आईडी
id
1 मैड्रिड 3
2 बर्लिन 2
3 पेरिस 1

तकनीकी रूप से, कॉलम country_id id . को संदर्भित करने वाली विदेशी कुंजी होनी चाहिए तालिका में कॉलम country . चूंकि आप चाहते हैं कि प्रत्येक पूंजी ठीक एक देश से जुड़ी हो, इसलिए आपको विदेशी कुंजी कॉलम country_id बनाना चाहिए अनोखा।

एक-से-एक संबंध व्यवहार में हैं

कुछ आमने-सामने के रिश्ते अंतिम

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

एक एकांगी संबंध टूट सकता है या भागीदारों में से एक की मृत्यु हो सकती है। यदि आप समय के साथ एकांगी संबंधों (जैसे विवाह या नागरिक संघ) की वास्तविकता को मॉडल करते हैं, तो आपको इस तथ्य को मॉडल करने की आवश्यकता होगी कि वे केवल एक निश्चित अवधि के लिए ही चलते हैं।

आपको लगता होगा कि एक व्यक्ति और उनकी उंगलियों के निशान कभी नहीं बदलते। लेकिन क्या होगा अगर व्यक्ति एक उंगली खो देता है या उंगली बुरी तरह जल जाती है? उनके फिंगरप्रिंट बदल सकते हैं। यह बहुत बार-बार होने वाला परिदृश्य नहीं है; फिर भी, कुछ मॉडलों में, आपको इसे ध्यान में रखना पड़ सकता है।

यहां तक ​​​​कि कुछ भी ऐसा प्रतीत होता है जैसे देश और उनकी राजधानियाँ समय के साथ बदलती हैं। उदाहरण के लिए, द्वितीय विश्व युद्ध के बाद, जब बर्लिन पूर्वी जर्मनी का हिस्सा था, बॉन पश्चिम जर्मनी (बुंडेस्रेपब्लिक ड्यूशलैंड) की राजधानी हुआ करता था। जर्मन पुनर्मिलन के बाद यह बदल गया; जर्मनी की राजधानी (बुंडेस्रेपब्लिक Deutschland) अब बर्लिन है। आपको इसे ध्यान में रखना चाहिए या नहीं यह आपकी व्यावसायिक वास्तविकता और उस एप्लिकेशन पर निर्भर करता है जिस पर आप काम कर रहे हैं।

एक व्यवहार्य 1:1 परिदृश्य:तालिका के वैकल्पिक भाग

मैं वास्तविक एक-से-एक संबंध के लिए एक व्यवहार्य परिदृश्य के बारे में सोच सकता हूं:तालिका के वैकल्पिक भाग। कल्पना कीजिए कि आपके पास तालिका है उपयोगकर्ता उपयोगकर्ता डेटा के साथ। तालिका में सामान्य उपयोगकर्ता जानकारी होती है, जैसे उपयोगकर्ता के नाम, ईमेल पते और साइनअप तिथियां। इसमें उपयोगकर्ता सेटिंग्स भी शामिल हैं, जैसे कि उस ऐप के लिए रंग थीम या ऑटो-लॉगिन। हालांकि, अधिकांश उपयोगकर्ताओं के पास कोई उपयोगकर्ता सेटिंग नहीं होती है; वे डिफ़ॉल्ट सेटिंग्स का उपयोग करते हैं।

user

<वें शैली="पृष्ठभूमि-रंग:#cecece">नाम <वें शैली="पृष्ठभूमि-रंग:#cecece">साइनअप_ तिथि <थ शैली="पृष्ठभूमि-रंग:#cecece">थीम
id ईमेल ऑटोलॉगिन
1 नथानेल टैलबोट [email protected] 2020-12-12 अंधेरा सच
2 तलिता येट्स [email protected] 2020-12-14
3 मार्कस वियर [email protected] 2020-12-15 प्रकाश झूठा
4 नथाली हेज़ [email protected] 2020-12-18
5 मौरिस चर्च [email protected] 2020-12-20
6 अरवा वाल्डेज़ [email protected] 2020-12-21

इस तालिका में बहुत सारे खाली क्षेत्र हैं। आप user तालिका को दो तालिकाओं में विभाजित करें:user और user_settings , जिसमें उन लोगों के लिए उपयोगकर्ता सेटिंग्स के बारे में जानकारी है जिन्होंने उन्हें चुनना चुना है।

user

<वें शैली="पृष्ठभूमि-रंग:#cecece">नाम <वें शैली="पृष्ठभूमि-रंग:#cecece">साइनअप_ तिथि <थ शैली="पृष्ठभूमि-रंग:#cecece">थीम
id ईमेल ऑटोलॉगिन
1 नथानेल टैलबोट [email protected] 2020-12-12 अंधेरा सच
2 तलिता येट्स [email protected] 2020-12-14
3 मार्कस वियर [email protected] 2020-12-15 प्रकाश झूठा
4 नथाली हेज़ [email protected] 2020-12-18
5 मौरिस चर्च [email protected] 2020-12-20
6 अरवा वाल्डेज़ [email protected] 2020-12-21

user_settings

<थ शैली="पृष्ठभूमि-रंग:#cecece">थीम
user_id ऑटोलॉगिन
1 अंधेरा सच
3 प्रकाश झूठा

डेटा को दो तालिकाओं में विभाजित करने से तालिका क्वेरी करना अधिक जटिल हो जाता है:आपको दोनों तालिकाओं के डेटा को जोड़ना होगा। दूसरी ओर, मुख्य उपयोगकर्ता तालिका को प्रबंधित करना आसान है।

डेटाबेस संबंधों के बारे में अधिक जानें

एक-से-एक संबंध एक ऐसा संबंध है जहां एक तालिका में एक रिकॉर्ड दूसरी तालिका में ठीक एक रिकॉर्ड से जुड़ा होता है। इस तरह का रिश्ता असल जिंदगी में कम ही देखने को मिलता है। यदि आप अपने डेटा मॉडल में समय शामिल करते हैं, तो कई एक-से-एक संबंध एक-से-अनेक या अनेक-से-अनेक संबंध बन जाते हैं। डेटाबेस में एक-से-एक संबंध का उपयोग करने के लिए सबसे आम परिदृश्य एक तालिका को दो में विभाजित करना है:एक अनिवार्य कॉलम के साथ, दूसरा वैकल्पिक कॉलम के साथ।

अगर आपको यह लेख पसंद आया है, तो हमारे ब्लॉग पर एक से कई और कई से कई संबंधों पर अन्य लेख देखें।

यदि आप डेटाबेस क्लास लेने वाले छात्र हैं, तो हमारे ऑनलाइन ईआर डायग्राम ड्राइंग टूल, वर्टाबेलो में एक निःशुल्क शैक्षणिक खाता बनाना सुनिश्चित करें। वर्टाबेलो आपको सीधे अपने ब्राउज़र में तार्किक और भौतिक ईआर आरेख बनाने की अनुमति देता है। यह PostgreSQL, SQL Server, Oracle, MySQL, Google BigQuery, Amazon Redshift और अन्य रिलेशनल डेटाबेस को सपोर्ट करता है। इसे आज़माएं और देखें कि आरंभ करना कितना आसान है!


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. शुरुआती के लिए ऑपरेटर के बीच एसक्यूएल

  2. Microsoft Power BI में डेटा कैसे लोड और प्रबंधित करें?

  3. उपलब्धता समूह कनेक्टिविटी को कॉन्फ़िगर करना

  4. डेटाबेस डिजाइन में कदम क्या हैं?

  5. SQL में डेटाबेस कैसे बनाते हैं?