HSQLDB - जुड़ता है

जब भी एक क्वेरी का उपयोग करके कई तालिकाओं से डेटा पुनर्प्राप्त करने की आवश्यकता होती है, तो आप RDBMS से JOINS का उपयोग कर सकते हैं। आप अपनी एकल SQL क्वेरी में कई तालिकाओं का उपयोग कर सकते हैं। HSQLDB में शामिल होने का कार्य एक ही तालिका में दो या अधिक तालिकाओं को नष्ट करने को संदर्भित करता है।

निम्नलिखित ग्राहकों और आदेश तालिकाओं पर विचार करें।

Customer:
+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+
Orders:
+-----+---------------------+-------------+--------+
|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  |
+-----+---------------------+-------------+--------+

अब, आइए हम ग्राहकों के डेटा और ऑर्डर राशि को संबंधित ग्राहक को पुनः प्राप्त करने का प्रयास करें। इसका मतलब है कि हम ग्राहकों और ऑर्डर टेबल दोनों से रिकॉर्ड डेटा प्राप्त कर रहे हैं। हम HSQLDB में JOINS अवधारणा का उपयोग करके इसे प्राप्त कर सकते हैं। निम्नलिखित उसी के लिए JOIN क्वेरी है।

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  |
+----+----------+-----+--------+

टाइप करें

HSQLDB में विभिन्न प्रकार के जोड़ उपलब्ध हैं।

  • INNER JOIN - दोनों टेबल में मैच होने पर पंक्तियों को वापस करता है।

  • LEFT JOIN - बाईं तालिका से सभी पंक्तियों को लौटाता है, भले ही दाएं तालिका में कोई मिलान न हो।

  • RIGHT JOIN - दाएं टेबल से सभी पंक्तियों को लौटाता है, भले ही बाईं तालिका में कोई मैच न हो।

  • FULL JOIN - तालिकाओं में से एक में एक मैच होने पर पंक्तियों को वापस करता है।

  • SELF JOIN - अपने आप में एक तालिका में शामिल होने के लिए उपयोग किया जाता है जैसे कि तालिका दो तालिकाएँ थीं, अस्थायी रूप से SQL कथन में कम से कम एक तालिका का नाम बदलकर।

आंतरिक रूप से जुड़ा

सबसे अधिक बार उपयोग किया जाता है और जुड़ने में महत्वपूर्ण INNER JOIN है। इसे EQUIJOIN के रूप में भी जाना जाता है।

INNER JOIN, दो विधेयकों (table1 और table2) के स्तंभ मानों को जोड़-जोड़ के आधार पर एक नया परिणाम तालिका बनाता है। क्वेरी तालिका 2 के प्रत्येक पंक्ति के साथ तालिका 1 की प्रत्येक पंक्ति की तुलना सभी पंक्तियों के जोड़े को खोजने के लिए करती है, जो जॉइन-प्रेडिकेट को संतुष्ट करती है। जब जॉइन-प्रेडिकेट संतुष्ट हो जाता है, तो ए और बी की प्रत्येक मिलान जोड़ी के लिए कॉलम मान एक परिणाम पंक्ति में संयुक्त होते हैं।

वाक्य - विन्यास

INNER JOIN का मूल सिंटैक्स इस प्रकार है।

SELECT table1.column1, table2.column2...
FROM table1
INNER JOIN table2
ON table1.common_field = table2.common_field;

उदाहरण

निम्न दो तालिकाओं पर विचार करें, एक शीर्षक तालिका के रूप में और दूसरा शीर्षक तालिका के रूप में निम्नानुसार है -

+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+
+-----+---------------------+-------------+--------+
| 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   |
+-----+---------------------+-------------+--------+

अब, हम इन दो तालिकाओं में शामिल होने के लिए इनर जॉइन क्वेरी का उपयोग निम्नानुसार करते हैं -

SELECT ID, NAME, AMOUNT, DATE FROM CUSTOMERS
INNER JOIN ORDERS
ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

उपरोक्त क्वेरी के निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होगा।

+----+----------+--------+---------------------+
| ID |   NAME   | AMOUNT |         DATE        |
+----+----------+--------+---------------------+
| 3  |  kaushik |  3000  | 2009-10-08 00:00:00 |
| 3  |  kaushik |  1500  | 2009-10-08 00:00:00 |
| 2  |  Khilan  |  1560  | 2009-11-20 00:00:00 |
| 4  | Chaitali |  2060  | 2008-05-20 00:00:00 |
+----+----------+--------+---------------------+

बाँया जोड़

HSQLDB LEFT JOIN दायीं मेज में कोई मेल न होने पर भी, बाईं मेज से सभी पंक्तियों को वापस कर देता है। इसका मतलब यह है कि यदि ऑन क्लॉज दाएं टेबल में 0 (शून्य) रिकॉर्ड से मेल खाता है, तो परिणाम में पंक्ति अभी भी एक पंक्ति में वापस आ जाएगी, लेकिन राइट टेबल से प्रत्येक कॉलम में NULL के साथ।

इसका मतलब यह है कि एक बाईं ओर से जुड़ने से सभी मानों की वापसी तालिका से होती है, साथ ही मिलान न होने की स्थिति में, सही तालिका या NULL से मिलान किए गए मानों का मिलान करें।

वाक्य - विन्यास

LEFT JOIN का मूल सिंटैक्स इस प्रकार है -

SELECT table1.column1, table2.column2...
FROM table1
LEFT JOIN table2
ON table1.common_field = table2.common_field;

यहां दी गई शर्त आपकी आवश्यकता के आधार पर दी गई कोई भी अभिव्यक्ति हो सकती है।

उदाहरण

निम्न दो तालिकाओं पर विचार करें, एक शीर्षक तालिका के रूप में और दूसरा शीर्षक तालिका के रूप में निम्नानुसार है -

+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+
+-----+---------------------+-------------+--------+
| 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   |
+-----+---------------------+-------------+--------+

अब, निम्न के रूप में LEFT JOIN क्वेरी का उपयोग करते हुए इन दो तालिकाओं में शामिल होते हैं -

SELECT ID, NAME, AMOUNT, DATE FROM CUSTOMERS
LEFT JOIN ORDERS
ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

उपरोक्त क्वेरी के निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

+----+----------+--------+---------------------+
| ID |   NAME   | AMOUNT |         DATE        |
+----+----------+--------+---------------------+
|  1 |  Ramesh  |  NULL  |        NULL         |
|  2 |  Khilan  |  1560  | 2009-11-20 00:00:00 |
|  3 |  kaushik |  3000  | 2009-10-08 00:00:00 |
|  3 |  kaushik |  1500  | 2009-10-08 00:00:00 |
|  4 | Chaitali |  2060  | 2008-05-20 00:00:00 |
|  5 |  Hardik  |  NULL  |        NULL         |
|  6 |  Komal   |  NULL  |        NULL         |
|  7 |  Muffy   |  NULL  |        NULL         |
+----+----------+--------+---------------------+

राइट जॉइन करें

HSQLDB राइट जॉइन सभी पंक्तियों को सही तालिका से लौटाता है, भले ही बाईं तालिका में कोई मेल न हो। इसका मतलब यह है कि अगर ओन क्लॉज लेफ्ट टेबल में 0 (शून्य) रिकॉर्ड करता है, तो जॉइन्ट रिजल्ट में एक पंक्ति देगा, लेकिन लेफ्ट टेबल से प्रत्येक कॉलम में NULL के साथ।

इसका मतलब यह है कि एक दाईं ओर से जुड़ने से सभी मानों का मिलान सही तालिका से होता है, साथ ही बाईं मिलान तालिका से मिलान किए गए मानों या NULL से मिलान न होने की स्थिति में पूर्ण मिलान से रिटर्न होता है।

वाक्य - विन्यास

का मूल सिंटैक्स RIGHT JOIN इस प्रकार है -

SELECT table1.column1, table2.column2...
FROM table1
RIGHT JOIN table2
ON table1.common_field = table2.common_field;

उदाहरण

निम्न दो तालिकाओं पर विचार करें, एक शीर्षक तालिका के रूप में और दूसरा शीर्षक तालिका के रूप में निम्नानुसार है -

+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+
+-----+---------------------+-------------+--------+
| 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  |
+-----+---------------------+-------------+--------+

अब, निम्न के रूप में राइट जॉइन क्वेरी का उपयोग करते हुए इन दो तालिकाओं में शामिल होते हैं -

SELECT ID, NAME, AMOUNT, DATE FROM CUSTOMERS
RIGHT JOIN ORDERS
ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

उपरोक्त क्वेरी के निष्पादन के बाद, आपको निम्नलिखित परिणाम प्राप्त होंगे।

+------+----------+--------+---------------------+
|  ID  |   NAME   | AMOUNT |        DATE         |
+------+----------+--------+---------------------+
|  3   |  kaushik |  3000  | 2009-10-08 00:00:00 |
|  3   |  kaushik |  1500  | 2009-10-08 00:00:00 |
|  2   |  Khilan  |  1560  | 2009-11-20 00:00:00 |
|  4   | Chaitali |  2060  | 2008-05-20 00:00:00 |
+------+----------+--------+---------------------+

पूर्ण सम्मिलित हों

HSQLDB पूर्ण जॉइन बाएँ और दाएँ दोनों बाहरी जॉइन के परिणामों को जोड़ती है।

शामिल तालिका में दोनों तालिकाओं से सभी रिकॉर्ड होंगे, और दोनों तरफ लापता मैचों के लिए NULLs भरें।

वाक्य - विन्यास

पूर्ण जॉइन का मूल सिंटैक्स इस प्रकार है -

SELECT table1.column1, table2.column2...
FROM table1
FULL JOIN table2
ON table1.common_field = table2.common_field;

यहां दी गई शर्त आपकी आवश्यकता के आधार पर दी गई कोई भी अभिव्यक्ति हो सकती है।

उदाहरण

निम्न दो तालिकाओं पर विचार करें, एक शीर्षक तालिका के रूप में और दूसरा शीर्षक तालिका के रूप में निम्नानुसार है -

+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+
+-----+---------------------+-------------+--------+
| 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   |
+-----+---------------------+-------------+--------+

अब, हम इस तरह की फुल जॉइन क्वेरी का उपयोग करते हुए इन दो तालिकाओं में शामिल होते हैं -

SELECT ID, NAME, AMOUNT, DATE FROM CUSTOMERS
FULL JOIN ORDERS
ON CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

उपरोक्त क्वेरी के निष्पादन के बाद, आपको निम्नलिखित परिणाम प्राप्त होंगे।

+------+----------+--------+---------------------+
|  ID  |    NAME  | AMOUNT |        DATE         |
+------+----------+--------+---------------------+
|   1  |  Ramesh  |  NULL  |        NULL         |
|   2  |  Khilan  |  1560  | 2009-11-20 00:00:00 |
|   3  |  kaushik |  3000  | 2009-10-08 00:00:00 |
|   3  |  kaushik |  1500  | 2009-10-08 00:00:00 |
|   4  | Chaitali |  2060  | 2008-05-20 00:00:00 |
|   5  |  Hardik  |  NULL  |        NULL         |
|   6  |   Komal  |  NULL  |        NULL         |
|   7  |   Muffy  |  NULL  |        NULL         |
|   3  |  kaushik |  3000  | 2009-10-08 00:00:00 |
|   3  |  kaushik |  1500  | 2009-10-08 00:00:00 |
|   2  |  Khilan  |  1560  | 2009-11-20 00:00:00 |
|   4  | Chaitali |  2060  | 2008-05-20 00:00:00 |
+------+----------+--------+---------------------+

स्वयं सम्मिलित हों

SQL SELF JOIN का उपयोग किसी तालिका को स्वयं में शामिल करने के लिए किया जाता है जैसे कि तालिका दो तालिकाएँ थीं, अस्थायी रूप से SQL कथन में कम से कम एक तालिका का नाम बदलकर।

वाक्य - विन्यास

SELF JOIN का मूल सिंटैक्स इस प्रकार है -

SELECT a.column_name, b.column_name...
FROM table1 a, table1 b
WHERE a.common_field = b.common_field;

यहां, आपकी आवश्यकता के आधार पर WHERE क्लॉज किसी भी दी गई अभिव्यक्ति हो सकती है।

उदाहरण

निम्न दो तालिकाओं पर विचार करें, एक शीर्षक तालिका के रूप में और दूसरा शीर्षक तालिका के रूप में निम्नानुसार है -

+----+----------+-----+-----------+----------+
| 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 |
+----+----------+-----+-----------+----------+

अब, इस तालिका को SELF JOIN क्वेरी का उपयोग करके इस तालिका में शामिल करें -

SELECT a.ID, b.NAME, a.SALARY FROM CUSTOMERS a, CUSTOMERS b
WHERE a.SALARY > b.SALARY;

उपरोक्त क्वेरी के निष्पादन के बाद, आपको निम्न आउटपुट प्राप्त होंगे -

+----+----------+---------+
| ID |   NAME   | SALARY  |
+----+----------+---------+
| 2  |  Ramesh  | 1500.00 |
| 2  |  kaushik | 1500.00 |
| 1  | Chaitali | 2000.00 |
| 2  | Chaitali | 1500.00 |
| 3  | Chaitali | 2000.00 |
| 6  | Chaitali | 4500.00 |
| 1  |  Hardik  | 2000.00 |
| 2  |  Hardik  | 1500.00 |
| 3  |  Hardik  | 2000.00 |
| 4  |  Hardik  | 6500.00 |
| 6  |  Hardik  | 4500.00 |
| 1  |  Komal   | 2000.00 |
| 2  |  Komal   | 1500.00 |
| 3  |  Komal   | 2000.00 |
| 1  |  Muffy   | 2000.00 |
| 2  |  Muffy   | 1500.00 |
| 3  |  Muffy   | 2000.00 |
| 4  |  Muffy   | 6500.00 |
| 5  |  Muffy   | 8500.00 |
| 6  |  Muffy   | 4500.00 |
+----+----------+---------+