sql - "इनर जॉइन" और "बाहरी जॉइन" के बीच क्या अंतर है?
database join (20)
LEFT JOIN
, RIGHT JOIN
और FULL JOIN
फिट करते हैं?
"इनर जॉइन" और "बाहरी जॉइन" के बीच क्या अंतर है?
वे एसक्यूएल में सबसे अधिक इस्तेमाल किए जाने वाले अस्तित्व वाले ऑपरेटरों हैं, जहां INNER JOIN
'अस्तित्व' के LEFT OUTER JOIN
लिए उपयोग किया जाता है और 'अस्तित्व में नहीं है' के लिए प्रयोग किया जाता है।
इन प्रश्नों पर विचार करें:
users who have posted and have votes
users who have posted but have no badges
जो लोग सेट-आधारित समाधान (एक उद्योग शब्द) की तलाश करते हैं, वे संबंधित प्रश्नों को इस प्रकार पहचानेंगे:
users who have posted INTERSECT users who have votes
users who have posted MINUS users who have badges
इन्हें मानक एसक्यूएल में अनुवाद करना:
SELECT UserId FROM Posts
INTERSECT
SELECT UserId FROM Votes;
SELECT UserId FROM Posts
EXCEPT
SELECT UserId FROM Badges;
अन्य सेट समावेशन के समान लाइनों के साथ सोचेंगे:
users who have posted and IN the set of users who have votes
users who have posted and NOT IN the set of users who have badges
इन्हें मानक एसक्यूएल में अनुवाद करना:
SELECT UserId
FROM Posts
WHERE UserId IN ( SELECT UserId FROM Votes );
SELECT UserId
FROM Posts
WHERE UserId NOT IN ( SELECT UserId FROM Badges );
कुछ सेटों के भीतर 'अस्तित्व' के संदर्भ में सोचेंगे
users who have posted and EXIST in the set of users who have votes
users who have posted and do NOT EXIST in the set of users who have badges
मानक SQL (ध्यान दें कि हम अब यानी सीमा चर का उपयोग करने की आवश्यकता है में इन का अनुवाद p
, v
, b
):
SELECT p.UserId
FROM Posts p
WHERE EXISTS ( SELECT *
FROM Votes v
WHERE v.UserId = p.UserId );
SELECT p.UserId
FROM Posts p
WHERE NOT EXISTS ( SELECT *
FROM Badges b
WHERE b.UserId = p.UserId );
हालांकि, मैंने पाया है कि "उद्योग मानक" दृष्टिकोण विशेष रूप से जुड़ने का उपयोग करना है। मुझे नहीं पता कि सोच क्या है ( उपकरण का कानून ? समयपूर्व अनुकूलन ?), तो मैं सीधे वाक्यविन्यास पर जाऊंगा:
SELECT p.UserId
FROM Posts p
INNER JOIN Votes v ON v.UserId = p.UserId;
SELECT p.UserId
FROM Posts p
LEFT JOIN Badges b ON b.UserId = p.UserId
WHERE b.UserId IS NULL;
ध्यान देने योग्य बातें:
- केवल प्रक्षेपण से है
Users
लेकिन हम अभी भी उन सभी रेंज चर (की जरूरत हैp
,v
,b
) खोज स्थितियों के लिए। UserId IS NULL
खोज हालत के लिए 'अंतर्गत आता है'OUTER JOIN
लेकिन क्वेरी में काट दिया गया है।-
LEFT
उद्योग मानक है: पेशेवरों का उपयोग करने से बचने के लिए एक प्रश्न फिर से लिखना होगाRIGHT
! OUTER
तैयार किए गए कीवर्डLEFT OUTER JOIN
छोड़ा गया है।
अंतिम शब्द:
कभी-कभी प्रश्नों का उपयोग केवल यह निर्धारित करने के लिए किया जाता है कि मूल्य मौजूद हैं या किसी अन्य सेट में मौजूद नहीं हैं। प्रक्षेपित किए गए विशेषताओं ( SELECT
खंड में कॉलम ) पर ध्यान से देखना सीखें : यदि शामिल तालिका से कोई भी नहीं है तो उन्हें केवल अस्तित्व वाले ऑपरेटरों के रूप में उपयोग किया जा रहा है। इसके अतिरिक्त बाहरी शामिल होने के लिए, खंड <key_column> IS NULL
में उदाहरणों की तलाश करें WHERE
।
आंतरिक रूप से जुड़ा
मिलान की गई पंक्तियों को केवल पुनर्प्राप्त करें, यानी, A intersect B
।
SELECT *
FROM dbo.Students S
INNER JOIN dbo.Advisors A
ON S.Advisor_ID = A.Advisor_ID
बाईं ओर का बाहरी जोड़
पहली तालिका से सभी रिकॉर्ड्स का चयन करें, और दूसरी तालिका में किसी भी रिकॉर्ड जो कि जुड़ी कुंजी से मेल खाता है।
SELECT *
FROM dbo.Students S
LEFT JOIN dbo.Advisors A
ON S.Advisor_ID = A.Advisor_ID
पूर्ण बाहरी शामिल हों
दूसरी तालिका से सभी रिकॉर्ड्स का चयन करें, और शामिल की गई कुंजी से मेल खाने वाली पहली तालिका में कोई भी रिकॉर्ड चुनें।
SELECT *
FROM dbo.Students S
FULL JOIN dbo.Advisors A
ON S.Advisor_ID = A.Advisor_ID
संदर्भ
इसके अलावा आप विभिन्न प्रकार के प्रकारों के लिए निम्न स्कीमा पर विचार कर सकते हैं;
स्रोत: सीएल मोफैट द्वारा विस्तार से समझाए गए Visual-Representation-of-SQL-Joins विज़ुअलाइजेशन
एक आंतरिक जुड़ाव केवल पंक्तियों को दिखाता है यदि जुड़ने के दूसरे (दाईं ओर) पर एक मिलान रिकॉर्ड है।
ए (बाएं) बाहरी जॉइन बाएं हाथ की ओर प्रत्येक रिकॉर्ड के लिए पंक्तियां दिखाता है, भले ही इसमें शामिल होने के दूसरे (दाईं ओर) कोई मिलान पंक्ति न हो। यदि कोई मिलान पंक्ति नहीं है, तो दूसरे (दाएं) पक्ष के कॉलम NULL दिखाएंगे।
परिणामों को एक नई, अस्थायी तालिका के साथ, दो तालिकाओं से डेटा को गठबंधन करने के लिए उपयोग किया जाता है। जॉइन को भविष्यवाणी नामक किसी चीज़ के आधार पर किया जाता है, जो शामिल होने के लिए उपयोग करने की स्थिति निर्दिष्ट करता है। एक आंतरिक शामिल होने और बाहरी जुड़ाव के बीच का अंतर यह है कि एक आंतरिक जुड़ाव केवल उन पंक्तियों को वापस कर देगा जो वास्तव में शामिल होने के आधार पर मेल खाते हैं। आइए कर्मचारी और स्थान तालिका पर विचार करें:
आंतरिक शामिल हों: - आंतरिक शामिल होने पर आधारित दो तालिकाओं ( कर्मचारी और स्थान ) के कॉलम मानों को संयोजित करके आंतरिक परिणाम एक नई परिणाम तालिका बनाता है। प्रश्न पंक्तियों के सभी जोड़े को खोजने के लिए नियोक्ता की प्रत्येक पंक्ति की तुलना में नियोक्ता की प्रत्येक पंक्ति की तुलना करता है जो जुड़ने वाले भविष्य को संतुष्ट करता है। जब गैर-नल मानों से मेल खाते हुए जुड़ने से संतुष्ट होता है, तो नियोक्ता और स्थान की पंक्तियों की प्रत्येक मिलान की जोड़ी के लिए कॉलम मान परिणाम पंक्ति में संयुक्त होते हैं। यहां एक आंतरिक शामिल होने के लिए एसक्यूएल जैसा दिखता है:
select * from employee inner join location on employee.empID = location.empID
OR
select * from employee, location where employee.empID = location.empID
अब, एसक्यूएल चलाने का नतीजा यह है कि ऐसा दिखाई देगा:
बाहरी शामिल हों: - एक बाहरी जुड़ने के लिए मिलान करने वाले रिकॉर्ड के लिए दो शामिल तालिकाओं में प्रत्येक रिकॉर्ड की आवश्यकता नहीं होती है। शामिल तालिका प्रत्येक रिकॉर्ड को बरकरार रखती है-भले ही कोई अन्य मिलान रिकॉर्ड मौजूद न हो। कौन सा टेबल की पंक्तियों को बनाए रखा जाता है (बाएं या दाएं) के आधार पर बाहरी बाएं बाहरी जोड़ों और दाएं बाहरी जुड़ने में आगे बढ़ता है।
बाएं बाहरी शामिल हों: - तालिकाओं के लिए बाएं बाहरी जुड़ने (या बस बाएं शामिल) का परिणाम कर्मचारी और स्थान में हमेशा "बाएं" तालिका ( कर्मचारी ) के सभी रिकॉर्ड होते हैं, भले ही जॉइन-हालत में कोई मिलान रिकॉर्ड न हो "दाएं" तालिका ( स्थान )। उपर्युक्त सारणी का उपयोग करके बाएं बाहरी जुड़ने के लिए एसक्यूएल जैसा दिखता है:
select * from employee left outer join location on employee.empID = location.empID;
//Use of outer keyword is optional
अब, यह एसक्यूएल चलाने का नतीजा यहां दिखेगा:
दायां बाहरी शामिल हों: - तालिकाओं के उपचार को छोड़कर, एक बाहरी बाहरी जुड़ाव (या दाएं शामिल) निकट बाएं बाहरी जुड़ने जैसा दिखता है। "दाएं" तालिका ( स्थान ) से प्रत्येक पंक्ति कम से कम एक बार शामिल तालिका में दिखाई देगी। यदि "बाएं" तालिका ( कर्मचारी ) से कोई मिलान पंक्ति मौजूद नहीं है, तो उन रिकॉर्ड्स के लिए कर्मचारी से कॉलम में NULL दिखाई देगा जिनके पास स्थान में कोई मिलान नहीं है। एसक्यूएल इस तरह दिखता है:
select * from employee right outer join location on employee.empID = location.empID;
//Use of outer keyword is optional
उपर्युक्त सारणी का उपयोग करके, हम दिखा सकते हैं कि सही बाहरी जुड़ने का परिणाम सेट कैसा दिखता है:
पूर्ण बाहरी जुड़ता है: - पूर्ण बाहरी शामिल हों या पूर्ण जुड़ें शामिल होने के परिणामों में नॉनमैचिंग पंक्तियों को शामिल करके नॉनमैचिंग जानकारी को बनाए रखना है, एक पूर्ण बाहरी शामिल होने का उपयोग करें। इसमें दोनों टेबलों की सभी पंक्तियां शामिल हैं, इस पर ध्यान दिए बिना कि अन्य तालिका का मिलान मूल्य है या नहीं।
मान लें कि आप कॉलम पर शामिल नहीं हो रहे हैं जिसमें कोई डुप्लीकेट नहीं है, जो एक बहुत ही आम मामला है:
ए और बी का एक आंतरिक जुड़ाव एक अंतरण बी का परिणाम देता है, यानी वेन आरेख चौराहे का आंतरिक हिस्सा।
ए और बी का बाहरी हिस्सा ए यूनियन बी, यानी वेन आरेख संघ के बाहरी हिस्सों के परिणाम देता है।
उदाहरण
मान लें कि आपके पास एक ही कॉलम के साथ दो टेबल हैं, और डेटा निम्नानुसार है:
A B
- -
1 3
2 4
3 5
4 6
ध्यान दें कि (1,2) ए के लिए अद्वितीय हैं, (3,4) आम हैं, और (5,6) बी के लिए अद्वितीय हैं।
आंतरिक रूप से जुड़ा
समकक्ष प्रश्नों में से किसी एक का उपयोग करने में एक आंतरिक शामिल होने से दो तालिकाओं का अंतरण मिलता है, यानी वे दो पंक्तियां आम हैं।
select * from a INNER JOIN b on a.a = b.b;
select a.*, b.* from a,b where a.a = b.b;
a | b
--+--
3 | 3
4 | 4
बाईं ओर का बाहरी जोड़
एक बाएं बाहरी जुड़ाव ए में सभी पंक्तियां, साथ ही बी में किसी भी आम पंक्तियां देगा।
select * from a LEFT OUTER JOIN b on a.a = b.b;
select a.*, b.* from a,b where a.a = b.b(+);
a | b
--+-----
1 | null
2 | null
3 | 3
4 | 4
सही बाहरी शामिल हों
एक सही बाहरी जुड़ाव बी में सभी पंक्तियां देगा, साथ ही ए में किसी भी आम पंक्तियां।
select * from a RIGHT OUTER JOIN b on a.a = b.b;
select a.*, b.* from a,b where a.a(+) = b.b;
a | b
-----+----
3 | 3
4 | 4
null | 5
null | 6
पूर्ण बाहरी शामिल हों
एक पूर्ण बाहरी जुड़ाव आपको ए और बी का संघ देगा, यानी ए में सभी पंक्तियां और बी में सभी पंक्तियां। यदि ए में कुछ बी में संबंधित डेटाम नहीं है, तो बी भाग शून्य है, और उपाध्यक्ष विपरीत।
select * from a FULL OUTER JOIN b on a.a = b.b;
a | b
-----+-----
1 | null
2 | null
3 | 3
4 | 4
null | 6
null | 5
वेन आरेख वास्तव में मेरे लिए यह नहीं करते हैं।
वे एक क्रॉस जॉइन और आंतरिक शामिल होने के बीच कोई भेद नहीं दिखाते हैं, उदाहरण के लिए, या अधिक आम तौर पर विभिन्न प्रकार के जुड़ने के पूर्वानुमान के बीच कोई भेद दिखाते हैं या वे कैसे काम करेंगे, इस बारे में तर्क के लिए एक ढांचा प्रदान करते हैं।
तार्किक प्रसंस्करण को समझने के लिए कोई विकल्प नहीं है और यह वैसे भी समझने के लिए अपेक्षाकृत सरल है।
- एक क्रॉस में शामिल होने की कल्पना करो।
- चरण 1 से सभी पंक्तियों के खिलाफ खंड
on
मूल्यांकन करें जहां अनुमानितtrue
मूल्यांकन करतेtrue
- (केवल बाहरी जुड़ने के लिए) चरण 2 में खोए गए बाहरी पंक्तियों में वापस जोड़ें।
(एनबी: अभ्यास में क्वेरी ऑप्टिमाइज़र उपर्युक्त तार्किक विवरण की तुलना में क्वेरी निष्पादित करने के अधिक कुशल तरीके ढूंढ सकता है लेकिन अंतिम परिणाम समान होना चाहिए)
मैं एक पूर्ण बाहरी शामिल होने के एनिमेटेड संस्करण के साथ शुरू कर दूंगा। आगे स्पष्टीकरण निम्नानुसार है।
व्याख्या
स्रोत सारणी
पहली बार CROSS JOIN
(एकेए कार्टेशियन उत्पाद) के साथ शुरू करें। इसमें कोई ON
क्लॉज नहीं है और केवल दो तालिकाओं से पंक्तियों के प्रत्येक संयोजन को लौटाता है।
एक क्रॉस जॉइन बी से एक रंग, बी। रंग चुनें
आंतरिक और बाहरी जुड़ने के लिए "चालू" खंड अनुमानित होता है।
- आंतरिक रूप से जुड़ा। परिणाम में क्रॉस में सभी पंक्तियों के लिए "चालू" खंड में स्थिति का मूल्यांकन करें। यदि सच में शामिल पंक्ति को वापस कर दें। अन्यथा इसे छोड़ दें।
- बाईं ओर का बाहरी जोड़। बाएं टेबल में किसी भी पंक्ति के लिए आंतरिक रूप से शामिल होने के समान ही, जो सही तालिका कॉलम के लिए इन्हें नल मानों के साथ आउटपुट से मेल नहीं खाता था।
- दाएं बाहरी शामिल हों। दाएं तालिका में किसी भी पंक्ति के लिए आंतरिक रूप से शामिल होने के समान ही जो बाएं तालिका कॉलम के लिए नल मानों के साथ आउटपुट से मेल नहीं खाता है।
- पूर्ण बाहरी शामिल हों। आंतरिक जुड़ने के समान ही बाएं गैर मिलान वाली पंक्तियों को बाएं बाहरी जोड़ों और सही बाहरी मिलान के अनुसार सही मिलान वाली पंक्तियों के रूप में सुरक्षित रखें।
कुछ उदाहरण
ए। कोलोर, बी। कोलर = बी। कोलोर पर बी में शामिल हों।
उपरोक्त क्लासिक इक्की शामिल है।
एनिमेटेड संस्करण
ए। कोलोर, बी। इनरर से बी में शामिल हों ए। कॉलोर इन नहीं ('ग्रीन', 'ब्लू')
आंतरिक जुड़ने की स्थिति को समानता की स्थिति की आवश्यकता नहीं होती है और इसे तालिकाओं के दोनों (या यहां तक कि) से कॉलम संदर्भित करने की आवश्यकता नहीं होती है। क्रॉस के प्रत्येक पंक्ति पर A.Colour NOT IN ('Green','Blue')
मूल्यांकन रिटर्न में शामिल होता है।
ए.कॉलर, बी। 1 से 1 में एक इंटर्नर बी बी से चुनें
क्रॉस में शामिल होने वाली सभी पंक्तियों के लिए जॉइन हालत सही साबित होती है, इसलिए यह क्रॉस जॉइन के समान ही है। मैं फिर से 16 पंक्तियों की तस्वीर दोहराना नहीं चाहूंगा।
AColour = B.Colour पर एक बाएं बाहरी जॉइन बी से एक रंग, बी। रंग चुनें।
बाहरी जॉइन का तर्कसंगत रूप से मूल्यांकन किया जाता है जैसे कि आंतरिक जुड़ता है सिवाय इसके कि अगर बाएं टेबल (बाएं शामिल होने के लिए) की पंक्ति दाएं हाथ की मेज से किसी भी पंक्ति में शामिल नहीं होती है, तो इसके परिणामस्वरूप यह NULL
मानों के साथ परिणाम में संरक्षित है दाहिने हाथ कॉलम।
एकोलर, बी। कोलोर पर एक बाएं बाहरी जॉइन बी से चुनें। बी.कॉलर जहां बी.कॉलर न्यूल है
यह पिछले परिणामों को केवल उन पंक्तियों को वापस करने के लिए प्रतिबंधित करता है जहां B.Colour IS NULL
। इस विशेष मामले में ये पंक्तियां होंगी जिन्हें संरक्षित किया गया था क्योंकि उनके पास दाएं हाथ की मेज में कोई मिलान नहीं था और क्वेरी तालिका B
में मेल नहीं की गई एक लाल पंक्ति को लौटाती है। इसे एक विरोधी अर्द्ध शामिल के रूप में जाना जाता है।
IS NULL
परीक्षण के लिए एक कॉलम चुनना महत्वपूर्ण है जो या तो IS NULL
नहीं है या जिसके लिए जॉइन की स्थिति सुनिश्चित करती है कि इस पैटर्न को सही तरीके से काम करने के लिए किसी भी NULL
मान को बाहर रखा जाएगा और केवल पंक्तियों को वापस लाने से बचें संयुक्त मिलान वाली पंक्तियों के अतिरिक्त उस कॉलम के लिए पूर्ण मान।
एकोलर, बी। कोलोर पर एक सही आउटर बी बी से चुनें।
दायां बाहरी जोड़ों को बाएं बाहरी जोड़ों के समान कार्य करता है सिवाय इसके कि वे सही तालिका से गैर मिलान पंक्तियों को सुरक्षित रखते हैं और नल बाएं हाथ कॉलम का विस्तार करते हैं।
एकोलर, बी। कोलोर पर एक पूर्ण बाहरी जॉइन बी से बी। सेलर, बी। रंग चुनें
पूर्ण बाहरी जुड़ने बाएं और दाएं जुड़ने के व्यवहार को जोड़ते हैं और बाएं और दाएं तालिकाओं से गैर मिलान पंक्तियों को संरक्षित करते हैं।
ए। कोलोर, बी। 1 से 0 पर एक पूर्ण बाहरी जॉइन बी से रंग चुनें
क्रॉस में कोई पंक्तियां 1=0
अनुमान से मेल नहीं खाती हैं। दोनों तरफ से सभी पंक्तियों को दूसरी तरफ टेबल से कॉलम में सामान्य के साथ सामान्य बाहरी शामिल नियमों का उपयोग करके संरक्षित किया जाता है।
1/0 पर एक पूर्ण बाहरी जॉइन बी से रंग के रूप में चयन कोलेस (एकोलोर, बी। कॉलोर)
एक मामूली पूछताछ में मामूली संशोधन के साथ एक UNION ALL
दो तालिकाओं का अनुकरण कर सकता है।
एकोलर, बी। कोलोर पर एक बाएं बाहरी जॉइन बी से चुनें। बी.कॉलर जहां बी.कोलर = 'ग्रीन'
ध्यान दें कि WHERE
खंड (यदि मौजूद है) शामिल होने के बाद तर्कसंगत रूप से चलता है। एक सामान्य त्रुटि बाएं बाहरी जुड़ने के लिए है और फिर दाएं तालिका पर एक शर्त के साथ एक WHERE क्लॉज शामिल है जो गैर मेल खाने वाली पंक्तियों को छोड़कर समाप्त होता है। उपरोक्त समाप्त होता है बाहरी बहिष्कार प्रदर्शन ...
... और फिर "कहां" खंड चलता है। NULL= 'Green'
सत्य का मूल्यांकन नहीं करता है, इसलिए बाहरी जोड़ों द्वारा संरक्षित पंक्ति को समाप्त कर दिया जाता है (नीले रंग के साथ) प्रभावशाली रूप से वापस एक आंतरिक में परिवर्तित हो जाता है।
यदि इरादा बी से केवल पंक्तियों को शामिल करना था जहां रंग ग्रीन है और सही वाक्यविन्यास के बावजूद ए से सभी पंक्तियां होंगी
एकोलर, बी। कोलोर और बी। कोलोर = 'ग्रीन' पर एक बाएं बाहरी जॉइन बी से बी। कॉलोर, बी रंग चुनें।
एसक्यूएल फिडल
इन उदाहरणों को SQLFiddle.com पर लाइव चलाएं देखें।
सरल शब्दों में:
एक आंतरिक मिलान केवल मिलान पंक्तियों को पुनः प्राप्त करें।
जबकि एक बाहरी मिलान एक तालिका से मेल खाने वाली पंक्तियों और अन्य पंक्तियों में सभी पंक्तियों को पुनर्प्राप्त करता है .... परिणाम इस बात पर निर्भर करता है कि आप किसका उपयोग कर रहे हैं:
बाएं : दाएं टेबल में मिलान पंक्तियां और बाएं तालिका में सभी पंक्तियां
दाएं : बाएं टेबल में मिलान की गई पंक्तियां और दाएं तालिका में सभी पंक्तियां या
पूर्ण : सभी तालिकाओं में सभी पंक्तियां। इससे कोई फर्क नहीं पड़ता कि कोई मैच है या नहीं
यह सभी तरह के जुड़ने के लिए एक अच्छा आरेखण स्पष्टीकरण है
स्रोत: http://ssiddique.info/understanding-sql-joins-in-easy-way.html
INNER JOIN
दो टेबल की तुलना में कम से कम एक मैच की आवश्यकता है। उदाहरण के लिए, तालिका ए और तालिका बी जो ए 8 बी (एक चौराहे बी) का तात्पर्य है।
LEFT OUTER JOIN
और LEFT JOIN
वही हैं। यह दोनों टेबलों और बाएं टेबल की सभी संभावनाओं से मेल खाने वाले सभी रिकॉर्ड देता है।
इसी प्रकार, RIGHT OUTER JOIN
और RIGHT JOIN
वही हैं। यह दोनों टेबलों और सही तालिका की सभी संभावनाओं से मेल खाने वाले सभी रिकॉर्ड देता है।
FULL JOIN
नकल के बिना LEFT OUTER JOIN
और RIGHT OUTER JOIN
बिना संयोजन है ।
आंतरिक रूप से जुड़ा।
एक जॉइन पंक्तियों को दो तालिकाओं से जोड़ रहा है। एक आंतरिक शामिल क्वेरी में निर्दिष्ट मानदंडों के आधार पर दो तालिकाओं से मेल खाने का प्रयास करता है, और केवल पंक्तियों को लौटाता है जो मेल खाते हैं। यदि जुड़ने में पहली तालिका से एक पंक्ति दूसरी तालिका में दो पंक्तियों से मेल खाती है, तो परिणामों में दो पंक्तियां वापस आ जाएंगी। यदि पहली तालिका में कोई पंक्ति है जो दूसरे पंक्ति में मेल नहीं खाती है, तो यह वापस नहीं आती है; इसी प्रकार, यदि दूसरी तालिका में कोई पंक्ति है जो पहले पंक्ति में मेल नहीं खाती है, तो यह वापस नहीं आती है।
बाहरी शामिल हों।
एक बाएं दूसरी तालिका में पंक्तियों को पहली तालिका से पंक्तियों से मिलान करने का प्रयास करने में प्रयास करती है। यदि यह कोई मिलान नहीं मिल रहा है, तो यह कॉलम को पहली तालिका से वापस कर देगा और कॉलम को दूसरी तालिका रिक्त (शून्य) से छोड़ देगा।
आंतरिक शामिल हों एक आंतरिक शामिल दो तालिकाओं के बीच समानता पर केंद्रित है। एक आंतरिक जुड़ने का उपयोग करते समय, तुलना की जा रही दो (या अधिक) तालिकाओं के बीच कम से कम कुछ मिलान डेटा होना चाहिए। एक आंतरिक डेटा मिलान या ओवरलैप करने के लिए खोज तालिका में शामिल हो जाता है। इसे खोजने पर, आंतरिक जुड़ने से जानकारी को एक नई तालिका में जोड़ दिया जाता है।
बाहरी शामिल हों एक बाहरी जॉइन रिकॉर्ड्स (या पंक्तियों) का एक सेट देता है जिसमें एक आंतरिक शामिल होगा, जिसमें अन्य पंक्तियां भी शामिल होंगी, जिसके लिए अन्य तालिका में कोई संबंधित मिलान नहीं मिलता है।
तीन प्रकार के बाहरी जुड़ते हैं:
बाएं बाहरी शामिल हों (या बाएं शामिल हों) दाएं बाहरी में शामिल हों (या राइट जॉइन) पूर्ण बाहरी शामिल हों (या पूर्ण जुड़ें) इनमें से प्रत्येक बाहरी जुड़ने से तुलना की जा रही डेटा के हिस्से को संदर्भित किया जाता है, जो संयुक्त, और लौटाया जा रहा है। कभी-कभी इस प्रक्रिया में नल का उत्पादन किया जाएगा क्योंकि कुछ डेटा साझा नहीं किया जाता है जबकि अन्य डेटा नहीं होता है।
आंतरिक शामिल होने और बाहरी जुड़ने के बीच का अंतर निम्नानुसार है:
- इनर जॉइन एक जुड़ाव है जो मेलिंग टुपल्स के आधार पर संयुक्त टेबल है, जबकि बाहरी जॉइन एक संयुक्त है जो मिलान और बेजोड़ टुपल दोनों के आधार पर संयुक्त तालिका है।
- आंतरिक जुड़ने वाली मिलान दो पंक्तियों से मिलान की गई पंक्ति में विलीन होती है जहां बेजोड़ पंक्ति छोड़ी जाती है, जबकि बाहरी जुड़ने दो पंक्तियों से पंक्तियों को विलय करती है और बेजोड़ पंक्तियां शून्य मान से भरती हैं।
- आंतरिक जुड़ाव एक चौराहे ऑपरेशन की तरह है, जबकि बाहरी जुड़ाव यूनियन ऑपरेशन की तरह है।
- आंतरिक जुड़ना दो प्रकार है, जबकि बाहरी जुड़ने तीन प्रकार हैं।
- आंतरिक जुड़ाव धीमा है, जबकि बाहरी जुड़ाव आंतरिक जुड़ने से तेज है।
जवाब प्रत्येक के अर्थ में है, इसलिए परिणामों में।
नोट:
इसमेंSQLite
कोई नहीं हैRIGHT OUTER JOIN
या नहींFULL OUTER JOIN
।
और इसमें भीMySQL
नहीं हैFULL OUTER JOIN
।
मेरा जवाब उपरोक्त नोट पर आधारित है ।
जब आपके पास दो टेबल हैं:
--[table1] --[table2]
id | name id | name
---+------- ---+-------
1 | a1 1 | a2
2 | b1 3 | b2
क्रॉस जॉइन / बाहरी जॉइन:
आप उन सभी टेबल डेटा के साथ CROSS JOIN
या बस ,
इस तरह के साथ हो सकते हैं:
SELECT * FROM table1, table2
--[OR]
SELECT * FROM table1 CROSS JOIN table2
--[Results:]
id | name | id | name
---+------+----+------
1 | a1 | 1 | a2
1 | a1 | 3 | b2
2 | b1 | 1 | a2
2 | b1 | 3 | b2
इनर जॉइन:
जब आप एक रिलेशनशिप के आधार पर उपरोक्त परिणामों में एक फ़िल्टर जोड़ना चाहते हैं जैसे table1.id = table2.id
आप इसका उपयोग कर सकते हैं INNER JOIN
:
SELECT * FROM table1, table2 WHERE table1.id = table2.id
--[OR]
SELECT * FROM table1 INNER JOIN table2 ON table1.id = table2.id
--[Results:]
id | name | id | name
---+------+----+------
1 | a1 | 1 | a2
बाएं [बाहरी] जॉइन:
जब आप उपर्युक्त परिणाम में तालिकाओं में से एक की सभी पंक्तियां रखना चाहते हैं- उसी संबंध के साथ- आप इसका उपयोग कर सकते हैं LEFT JOIN
:
( दाएं जॉइन के लिए बस टेबल की जगह बदलें)
SELECT * FROM table1, table2 WHERE table1.id = table2.id
UNION ALL
SELECT *, Null, Null FROM table1 WHERE Not table1.id In (SELECT id FROM table2)
--[OR]
SELECT * FROM table1 LEFT JOIN table2 ON table1.id = table2.id
--[Results:]
id | name | id | name
---+------+------+------
1 | a1 | 1 | a2
2 | b1 | Null | Null
पूर्ण आउटर जॉइन:
जब आप अपने परिणामों में दूसरी तालिका की सभी पंक्तियां भी लेना चाहते हैं तो आप इसका उपयोग कर सकते हैं FULL OUTER JOIN
:
SELECT * FROM table1, table2 WHERE table1.id = table2.id
UNION ALL
SELECT *, Null, Null FROM table1 WHERE Not table1.id In (SELECT id FROM table2)
UNION ALL
SELECT Null, Null, * FROM table2 WHERE Not table2.id In (SELECT id FROM table1)
--[OR] (recommended for SQLite)
SELECT * FROM table1 LEFT JOIN table2 ON table1.id = table2.id
UNION ALL
SELECT * FROM table2 LEFT JOIN table1 ON table2.id = table1.id
WHERE table1.id IS NULL
--[OR]
SELECT * FROM table1 FULL OUTER JOIN table2 On table1.id = table2.id
--[Results:]
id | name | id | name
-----+------+------+------
1 | a1 | 1 | a2
2 | b1 | Null | Null
Null | Null | 3 | b2
खैर, आपकी ज़रूरत के अनुसार आप अपनी जरूरत को पूरा करने वाले प्रत्येक व्यक्ति को चुनते हैं;)।
मुझे अन्य उत्तरों में प्रदर्शन और अनुकूलक के बारे में अधिक जानकारी नहीं दिखाई देती है।
कभी-कभी यह जानना अच्छा होता है कि केवल INNER JOIN
सहयोगी है जिसका अर्थ है कि अनुकूलक के पास इसके साथ खेलने का सबसे अधिक विकल्प है। यह उसी परिणाम को तेज़ी से बनाए रखने के लिए शामिल होने के क्रम में पुन: क्रमबद्ध कर सकता है। अनुकूलक सबसे अधिक शामिल मोड का उपयोग कर सकते हैं।
आम तौर पर INNER JOIN
विभिन्न प्रकार के जॉइन के बजाय उपयोग करने का प्रयास करना एक अच्छा अभ्यास है । (बेशक यदि अपेक्षित परिणाम सेट पर विचार करना संभव है।)
इस अजीब सहयोगी व्यवहार के बारे में यहां कुछ अच्छे उदाहरण और स्पष्टीकरण दिए गए हैं:
यदि कोई सामान्य रिकॉर्ड नहीं है तो अंतर में शामिल होने के तरीके में अंतर है।
JOIN
रूप में ही है INNER JOIN
और केवल शो रिकॉर्ड दोनों तालिकाओं के लिए आम का मतलब है। चाहे रिकॉर्ड्स आम हैं, खंड में शामिल फ़ील्ड द्वारा निर्धारित किया जाता है।
उदाहरण के लिए:
SELECT *
FROM t1
JOIN t2 on t1.ID = t2.ID
इसका मतलब है केवल रिकॉर्ड दिखाएं जहां एक ही ID
मूल्य दोनों तालिकाओं में मौजूद है।
LEFT JOIN
LEFT OUTER JOIN
दाएं तालिका में मिलान रिकॉर्ड के अस्तित्व के बावजूद बाएं तालिका से सभी रिकॉर्ड (यानी SQL कथन में पहले वाला) दिखाने के लिए समान है ।
RIGHT JOIN
जैसा RIGHT OUTER JOIN
कि विपरीत है और इसका मतलब है LEFT JOIN
, यानी दूसरी (दाएं) तालिका से सभी रिकॉर्ड दिखाता है और केवल पहले (बाएं) तालिका से मेल खाने वाले रिकॉर्ड दिखाता है।
समान्य शब्दों में,
1. अंदरूनी जॉइन या इक्की जॉइन: परिणामसेट देता है जो दोनों टेबलों में केवल स्थिति से मेल खाता है।
2. बाहरी जॉइन: स्थिति होने पर या नहीं, भले ही दोनों टेबलों से सभी मानों के परिणामसेट को वापस कर देता है।
3. बाएं जॉइन: बाएं टेबल से सभी मानों के परिणामसेट को लौटाता है और केवल पंक्तियां जो सही तालिका में स्थिति से मेल खाते हैं।
4. सही जॉइन: दाएं टेबल से सभी मानों के परिणामसेट को लौटाता है और केवल पंक्तियां जो बाएं तालिका में स्थिति से मेल खाते हैं।
5. पूर्ण जॉइन: पूर्ण जुड़ें और पूर्ण बाहरी शामिल हों।
सरल शब्दों में:
आंतरिक शामिल हों -> माता-पिता और बाल सारणी से केवल सामान्य रिकॉर्ड लें, जहां माता-पिता तालिका की प्राथमिक कुंजी बाल तालिका में विदेशी कुंजी से मेल खाती है।
बाएं शामिल हों ->
छद्म कोड
1.Take All records from left Table
2.for(each record in right table,) {
if(Records from left & right table matching on primary & foreign key){
use their values as it is as result of join at the right side for 2nd table.
} else {
put value NULL values in that particular record as result of join at the right side for 2nd table.
}
}
सही शामिल हों : बाएं जुड़ने के बिल्कुल विपरीत। राइट जॉइन में दाईं ओर बाएं जॉइन में टेबल का नाम दें, आपको बाएं जॉइन के समान आउटपुट मिलता है।
बाहरी शामिल हों : दोनों तालिकाओं में सभी रिकॉर्ड दिखाएं No matter what
। यदि बाएं तालिका में रिकॉर्ड्स प्राथमिक, फ़ॉरिगइन कुंजी के आधार पर सही तालिका से मेल नहीं खाते हैं, तो शामिल होने के परिणामस्वरूप न्यूल मान का उपयोग करें।
उदाहरण :
आइए अब 2 टेबल के लिए मान लें
1.employees , 2.phone_numbers_employees
employees : id , name
phone_numbers_employees : id , phone_num , emp_id
यहां, कर्मचारी तालिका मास्टर टेबल है, phone_numbers_employees बाल तालिका है (इसमें emp_id
विदेशी कुंजी है जो employee.id
इसकी बाल तालिका को जोड़ती है।)
अंदरूनी जुड़ता है
केवल 2 टेबल के रिकॉर्ड लें यदि कर्मचारी तालिका (इसकी आईडी) की प्राथमिक कुंजी बाल तालिका phone_numbers_employees (emp_id) की विदेशी कुंजी से मेल खाती है ।
तो सवाल होगा:
SELECT e.id , e.name , p.phone_num FROM employees AS e INNER JOIN phone_numbers_employees AS p ON e.id = p.emp_id;
यहां ऊपर वर्णित अनुसार प्राथमिक कुंजी = विदेशी कुंजी पर केवल मिलान पंक्तियां लें। प्राथमिक कुंजी पर गैर मेल खाने वाली पंक्तियां = विदेशी कुंजी को शामिल होने के परिणामस्वरूप छोड़ दिया जाता है।
बाएं जुड़ता है :
बाईं ओर बाएं टेबल की सभी पंक्तियों को बरकरार रखा गया है, भले ही सही पंक्ति पर मेल खाने वाली कोई पंक्ति हो।
SELECT e.id , e.name , p.phone_num FROM employees AS e LEFT JOIN phone_numbers_employees AS p ON e.id = p.emp_id;
बाहरी जुड़ता है :
SELECT e.id , e.name , p.phone_num FROM employees AS e OUTER JOIN phone_numbers_employees AS p ON e.id = p.emp_id;
आरेखण रूप से ऐसा लगता है:
आप INNER JOIN
दोनों टेबलों से सभी पंक्तियों को वापस करने के लिए उपयोग करते हैं जहां एक मैच होता है। यानी परिणामी तालिका में सभी पंक्तियों और स्तंभों के मूल्य होंगे।
में OUTER JOIN
जिसके परिणामस्वरूप तालिका खाली कॉलम हो सकता है। बाहरी जुड़ाव LEFT
या तो हो सकता है RIGHT
।
LEFT OUTER JOIN
पहली तालिका से सभी पंक्तियां लौटाती हैं, भले ही दूसरी तालिका में कोई मिलान न हो।
RIGHT OUTER JOIN
दूसरी तालिका से सभी पंक्तियां लौटाती हैं, भले ही पहली तालिका में कोई मिलान न हो।
के लिए सटीक एल्गोरिथ्म INNER JOIN
, LEFT/RIGHT OUTER JOIN
निम्न प्रकार हैं:
- प्रत्येक पंक्ति को पहली तालिका से लें:
a
- इसके बगल में दूसरी टेबल से सभी पंक्तियों पर विचार करें:
(a, b[i])
ON ...
प्रत्येक जोड़ी के खिलाफ खंड का मूल्यांकन करें :ON( a, b[i] ) = true/false?
- जब स्थिति का मूल्यांकन होता है
true
, तो उस संयुक्त पंक्ति को वापस कर दें(a, b[i])
। - किसी भी मैच के बिना दूसरी तालिका के अंत तक पहुंचने पर, और
Outer Join
फिर यह एक तालिका (वर्चुअल) जोड़ीNull
को अन्य तालिका के सभी कॉलम के लिए उपयोग कर देता है:(a, Null)
बाएं बाहरी जुड़ने के लिए या(Null, b)
दाएं बाहरी जुड़ने के लिए। यह सुनिश्चित करना है कि अंतिम तालिका की सभी पंक्तियां अंतिम परिणामों में मौजूद हैं।
- जब स्थिति का मूल्यांकन होता है
नोट:ON
खंड में निर्दिष्ट शर्त कुछ भी हो सकती है, प्राथमिक कुंजी का उपयोग करने की आवश्यकता नहीं है (और आपको हमेशा दोनों तालिकाओं के कॉलम को संदर्भित करने की आवश्यकता नहीं है)! उदाहरण के लिए:
-
... ON T1.title = T2.title AND T1.version < T2.version
(=> इस पोस्ट को नमूना उपयोग के रूप में देखें: कॉलम पर अधिकतम मान वाले पंक्तियों का चयन करें ) -
... ON T1.y IS NULL
-
... ON 1 = 0
(बस नमूना के रूप में)
नोट: बाएं जुड़ें = बाएं बाहरी शामिल हों, दाएं जुड़ें = दाएं बाहरी शामिल हों।