एसक्यूएल - जॉइन का उपयोग करना
एसक्यूएल Joinsक्लॉज का उपयोग डेटाबेस में दो या अधिक टेबल से रिकॉर्ड को संयोजित करने के लिए किया जाता है। एक JOIN प्रत्येक के लिए समान मूल्यों का उपयोग करके दो तालिकाओं से फ़ील्ड के संयोजन के लिए एक साधन है।
निम्नलिखित दो तालिकाओं पर विचार करें -
Table 1 - ग्राहक तालिका
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
Table 2 - आदेश तालिका
+-----+---------------------+-------------+--------+
|OID | DATE | CUSTOMER_ID | AMOUNT |
+-----+---------------------+-------------+--------+
| 102 | 2009-10-08 00:00:00 | 3 | 3000 |
| 100 | 2009-10-08 00:00:00 | 3 | 1500 |
| 101 | 2009-11-20 00:00:00 | 2 | 1560 |
| 103 | 2008-05-20 00:00:00 | 4 | 2060 |
+-----+---------------------+-------------+--------+
अब, नीचे दिए गए अनुसार हमारे चयन कथन में इन दो तालिकाओं को मिला दें।
SQL> SELECT ID, NAME, AGE, AMOUNT
FROM CUSTOMERS, ORDERS
WHERE CUSTOMERS.ID = ORDERS.CUSTOMER_ID;
यह निम्नलिखित परिणाम का उत्पादन करेगा।
+----+----------+-----+--------+
| ID | NAME | AGE | AMOUNT |
+----+----------+-----+--------+
| 3 | kaushik | 23 | 3000 |
| 3 | kaushik | 23 | 1500 |
| 2 | Khilan | 25 | 1560 |
| 4 | Chaitali | 25 | 2060 |
+----+----------+-----+--------+
यहां, यह ध्यान देने योग्य है कि ज्वाइन WHERE क्लॉज में किया जाता है। तालिकाओं में शामिल होने के लिए कई ऑपरेटरों का उपयोग किया जा सकता है, जैसे =, <,>, <>, <=,> =; =; = BETWEEN, LIKE, और NOT; वे सभी तालिकाओं में शामिल होने के लिए उपयोग किए जा सकते हैं। हालांकि, सबसे आम ऑपरेटर प्रतीक के बराबर है।
एसक्यूएल में विभिन्न प्रकार के जॉइन उपलब्ध हैं -
INNER JOIN - दोनों टेबलों में मैच होने पर पंक्तियाँ लौटाता है।
बाईं ओर - बाईं तालिका से सभी पंक्तियाँ लौटाता है, भले ही सही तालिका में कोई मेल न हों।
राइट जॉइन - दाएं टेबल से सभी पंक्तियों को लौटाता है, भले ही बाएं टेबल में कोई मैच न हो।
पूर्ण जॉइन - एक टेबल में एक मैच होने पर पंक्तियाँ लौटाता है।
SELF JOIN - का प्रयोग टेबल को खुद से जोड़ने के लिए किया जाता है जैसे कि टेबल दो टेबल थी, अस्थायी रूप से SQL स्टेटमेंट में कम से कम एक टेबल का नाम बदलकर।
कार्टिनियन जोन - दो या अधिक सम्मिलित तालिकाओं से रिकॉर्ड के सेट के कार्टेशियन उत्पाद को लौटाता है।
आइए अब हम इनमें से प्रत्येक जोड़ पर विस्तार से चर्चा करते हैं।