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

SQL सर्वर 2017 में संबंध बनाएं

SQL सर्वर में दो तालिकाओं के बीच संबंध बनाने का तरीका जानें।

रिलेशनल डेटाबेस डिज़ाइन में, एक रिलेशनशिप वह जगह है जहाँ दो या दो से अधिक तालिकाएँ एक साथ जुड़ी होती हैं क्योंकि उनमें संबंधित डेटा होता है। यह उपयोगकर्ताओं को कई तालिकाओं में संबंधित डेटा के लिए क्वेरी चलाने में सक्षम बनाता है।

ट्यूटोरियल का यह हिस्सा बताता है कि निम्नलिखित संबंध कैसे बनाएं:

उस आरेख में दो संबंध हैं। Albums . के बीच एक संबंध है और Artists टेबल, और Albums . के बीच एक और संबंध है और Genres टेबल.

उस आरेख को देखकर, हम देख सकते हैं कि एक कलाकार के पास कई एल्बम हो सकते हैं। इस मामले में, हमारे पास केवल एक पंक्ति होनी चाहिए जिसमें कलाकार का नाम हो, चाहे उनके पास कितने भी एल्बम हों। ऐसा इसलिए है क्योंकि हम Artists . में एक रिकॉर्ड बना सकते हैं एक अद्वितीय ArtistId . के साथ तालिका . उस कलाकार के सभी एल्बम Albums . में रहेंगे तालिका, और उनमें एक ही कलाकार आईडी अपने ArtistId . में होगी कॉलम। ऐसा करने से, हम दोनों तालिकाओं में एक क्वेरी चला सकते हैं और कलाकार का नाम, साथ ही उनके द्वारा जारी किए गए सभी एल्बम वापस कर सकते हैं। यही है रिश्तों का फायदा।

पहले हमने उपरोक्त तीन तालिकाओं वाला एक डेटाबेस बनाया था। जब हमने ऐसा किया, तो हमने उपरोक्त आरेख में दर्शाए गए संबंधों में से एक भी बनाया। हमने Albums . के बीच संबंध बनाया है तालिका और Artists तालिका (जहां ArtistId Albums . का कॉलम तालिका ArtistsId . का संदर्भ देती है Artists . का स्तंभ टेबल)।

टेबल बनाने के लिए हमने जो कोड चलाया वह यहां दिया गया है:

हाइलाइट किया गया कोड वह हिस्सा है जो Albums . के बीच संबंध बनाता है तालिका और Artists टेबल। यह ArtistId . सेट करके ऐसा करता है Albums . का कॉलम ArtistId . को संदर्भित करने के लिए Artists . का स्तंभ टेबल।

यह कहने का एक और तकनीकी तरीका यह है कि Albums.ArtistId Artists.ArtistId . की विदेशी कुंजी बन जाती है (जो स्वयं उस तालिका की प्राथमिक कुंजी है)। यह एक विदेशी कुंजी बाधा है।

विदेशी कुंजी प्रतिबंध क्या है?

एक विदेशी कुंजी बाधा इस तालिका और दूसरी तालिका के बीच संबंध को परिभाषित करता है। जब आप एक विदेशी कुंजी बाधा बनाते हैं, तो आप इसे बच्चे . में एक विशिष्ट कॉलम के विरुद्ध बनाते हैं तालिका, पैरेंट . में एक विशिष्ट कॉलम को संदर्भित करने के लिए टेबल।

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

यह संदर्भात्मक अखंडता को लागू करने में मदद करता है। यह हमें अनाथ रिकॉर्ड (बाल रिकॉर्ड जिनमें कोई माता-पिता नहीं है) होने से रोकता है। या हमारे उदाहरण में, ऐसे एल्बम जो किसी कलाकार से संबद्ध नहीं हैं।

यदि आप SSMS या Azure डेटा स्टूडियो जैसे GUI डेटाबेस प्रबंधन टूल का उपयोग करते हैं, तो संबंध Keys के अंतर्गत दिखाई देगा विदेशी कुंजी के साथ तालिका के लिए नोड:

आइए कोड का पुनर्निर्माण करें:

CONSTRAINT FK_Albums_Artists FOREIGN KEY (ArtistId)     
    REFERENCES dbo.Artists (ArtistId)     
    ON DELETE NO ACTION    
    ON UPDATE NO ACTION

पहली दो पंक्तियाँ संबंध बनाती हैं। वे Albums.ArtistId . के बीच एक विदेशी कुंजी बाधा उत्पन्न करते हैं कॉलम और Artist.ArtistId कॉलम। इस मामले में हम विदेशी कुंजी बाधा FK_Albums_Artists . कहते हैं ।

अंतिम दो पंक्तियाँ निर्दिष्ट करती हैं कि SQL सर्वर को क्या करना चाहिए यदि कोई पैरेंट रिकॉर्ड को हटाने या अद्यतन करने का प्रयास करता है जिसे चाइल्ड टेबल में रिकॉर्ड द्वारा संदर्भित किया जा रहा है। इस मामले में, NO ACTION इसका मतलब है कि डिलीट/अपडेट आगे नहीं बढ़ेगा। उपयोगकर्ता को बस एक त्रुटि मिलेगी।

आप इसे ON DELETE CASCADE . में बदल सकते हैं यदि आप माता-पिता और बच्चे को एक बार में हटाने में सक्षम होना चाहते हैं (यानी हटाना माता-पिता से बच्चे तक पहुंच जाएगा)। ON UPDATE CASADE . का उपयोग करके अपडेट पर भी यही तर्क लागू होता है ।

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

मौजूदा तालिका में संबंध जोड़ें

पिछला उदाहरण उसी समय एक संबंध बनाता है जब तालिकाएँ बनाई जाती हैं। हालाँकि, कई बार ऐसा भी हो सकता है कि आपको किसी मौजूदा तालिका में संबंध जोड़ने की आवश्यकता हो।

आइए Genres . के बीच एक नया संबंध जोड़ें और Albums टेबल.

निम्नलिखित कोड चलाएँ:

USE Music;   
ALTER TABLE Albums
ADD CONSTRAINT FK_Albums_Genres FOREIGN KEY (GenreId)     
	REFERENCES dbo.Genres (GenreId)     
	ON DELETE NO ACTION    
	ON UPDATE NO ACTION
;

यह Albums . पर एक नई विदेशी कुंजी बनाता है टेबल। इसका परिणाम Albums.GenreId . होता है Genres.GenreId . का संदर्भ देने वाली विदेशी कुंजी बनना ।

तो उस कथन को चलाने के परिणामस्वरूप कुंजी . के अंतर्गत एक नई विदेशी कुंजी प्रदर्शित की जा रही है नोड:

सिंगल कॉलम फॉरेन कीज

एकल स्तंभ विदेशी कुंजियाँ (जैसे ऊपर दी गई हैं) भी स्तंभ स्तर पर निर्दिष्ट की जा सकती हैं। तो Albums बनाने का दूसरा तरीका तालिका और उसकी विदेशी कुंजी इस प्रकार है:

CREATE TABLE Albums (
  AlbumId int IDENTITY(1,1) NOT NULL PRIMARY KEY,
  AlbumName nvarchar(255) NOT NULL,
  ReleaseDate date NOT NULL,
  ArtistId int NOT NULL
		REFERENCES Artists(ArtistId),
  GenreId int NOT NULL   
);

इस विधि का उपयोग बहु-स्तंभ कुंजी बाधाओं पर नहीं किया जा सकता है, इसलिए उनके लिए, उपरोक्त मूल उदाहरण में सिंटैक्स का उपयोग करें।

बहु-स्तंभ विदेशी कुंजियाँ

एक बहुस्तंभ विदेशी कुंजी वह है जहां विदेशी कुंजी के लिए एक से अधिक कॉलम का उपयोग किया जाता है। यह आमतौर पर तब उपयोग किया जाता है जब मूल तालिका अपनी प्राथमिक कुंजी के लिए एकाधिक कॉलम का उपयोग करती है। यह मामला हो सकता है यदि मूल तालिका एक अद्वितीय मान बनाने के लिए दो स्तंभों के मानों को जोड़ती है।

उपरोक्त मूल उदाहरण में वाक्य रचना का उपयोग करके बहु-स्तंभ विदेशी कुंजियाँ बनाई जा सकती हैं। बस प्रत्येक स्तंभ नाम को अल्पविराम से अलग करके जोड़ें।

तो अगर हम कल्पना करें कि Albums तालिका में एक ArtistName भी है कॉलम (और वह Artists तालिका ArtistId . का उपयोग करती है और ArtistName इसकी प्राथमिक कुंजी के रूप में), एक बहु-स्तंभ विदेशी कुंजी इस तरह दिखाई देगी:

CONSTRAINT FK_Albums_Artists FOREIGN KEY (ArtistId, ArtistName)     
    REFERENCES dbo.Artists (ArtistId, ArtistName)

  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL सर्वर (T-SQL) में डेटाबेस मेल प्रोफ़ाइल हटाएं

  2. वर्तमान में SQL सर्वर में उपयोग की जा रही भाषा प्राप्त करें

  3. Laravel . से संग्रहित प्रक्रिया को कैसे निष्पादित करें

  4. टी-एसक्यूएल में एसक्यूएल सर्वर नियमित अभिव्यक्ति

  5. SQL सर्वर 2014 की खोज समानांतरवाद में चुनें