PostgreSQL - JOINS

The PostgreSQL Joinsक्लॉज का उपयोग डेटाबेस में दो या अधिक टेबल से रिकॉर्ड को संयोजित करने के लिए किया जाता है। एक JOIN प्रत्येक के लिए समान मूल्यों का उपयोग करके दो तालिकाओं से फ़ील्ड के संयोजन के लिए एक साधन है।

PostgreSQL में शामिल प्रकार हैं -

  • क्रॉस जॉइन
  • INNER JOIN
  • बाईं ओर शामिल हैं
  • द राइट ऑप्टर जॉइन
  • फुल ऑवर जॉइन

आगे बढ़ने से पहले, आइए हम दो तालिकाओं पर विचार करें, Company और DEPARTMENT। हमने पहले से ही कंपनी तालिका को पॉप्युलेट करने के लिए INSERT बयान देखे हैं। तो बस हमें कंपनी तालिका में उपलब्ध अभिलेखों की सूची माननी चाहिए -

id | name  | age | address   | salary | join_date
----+-------+-----+-----------+--------+-----------
  1 | Paul  |  32 | California|  20000 | 2001-07-13
  3 | Teddy |  23 | Norway    |  20000 |
  4 | Mark  |  25 | Rich-Mond |  65000 | 2007-12-13
  5 | David |  27 | Texas     |  85000 | 2007-12-13
  2 | Allen |  25 | Texas     |        | 2007-12-13
  8 | Paul  |  24 | Houston   |  20000 | 2005-07-13
  9 | James |  44 | Norway    |   5000 | 2005-07-13
 10 | James |  45 | Texas     |   5000 | 2005-07-13

एक अन्य तालिका विभाग है, जिसकी निम्नलिखित परिभाषा है -

CREATE TABLE DEPARTMENT(
   ID INT PRIMARY KEY      NOT NULL,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);

यहाँ प्रस्तुत सारणी को भरने के लिए INSERT कथनों की सूची है -

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (1, 'IT Billing', 1 );

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (2, 'Engineering', 2 );

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (3, 'Finance', 7 );

अंत में, हमारे पास निम्नलिखित तालिका में उपलब्ध रिकॉर्ड की सूची है -

id | dept        | emp_id
----+-------------+--------
  1 | IT Billing  |  1
  2 | Engineering |  2
  3 | Finance     |  7

क्रॉस जॉइन

एक रॉस जॉइन पहली तालिका की हर पंक्ति के साथ दूसरी तालिका की हर पंक्ति से मेल खाता है। यदि इनपुट टेबल में क्रमशः x और y कॉलम हैं, तो परिणामी तालिका में x + y कॉलम होंगे। क्योंकि CROSS JOINs में बहुत बड़ी तालिकाओं को उत्पन्न करने की क्षमता होती है, इसलिए उचित होने पर ही उनका उपयोग करने के लिए ध्यान रखा जाना चाहिए।

निम्नलिखित क्रोस जॉइन का सिंटैक्स है -

SELECT ... FROM table1 CROSS JOIN table2 ...

उपरोक्त सारणियों के आधार पर, हम निम्नलिखित के रूप में एक क्रॉस जॉइन लिख सकते हैं -

testdb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY CROSS JOIN DEPARTMENT;

ऊपर दी गई क्वेरी निम्न परिणाम देगी -

emp_id| name  |  dept
------|-------|--------------
    1 | Paul  | IT Billing
    1 | Teddy | IT Billing
    1 | Mark  | IT Billing
    1 | David | IT Billing
    1 | Allen | IT Billing
    1 | Paul  | IT Billing
    1 | James | IT Billing
    1 | James | IT Billing
    2 | Paul  | Engineering
    2 | Teddy | Engineering
    2 | Mark  | Engineering
    2 | David | Engineering
    2 | Allen | Engineering
    2 | Paul  | Engineering
    2 | James | Engineering
    2 | James | Engineering
    7 | Paul  | Finance
    7 | Teddy | Finance
    7 | Mark  | Finance
    7 | David | Finance
    7 | Allen | Finance
    7 | Paul  | Finance
    7 | James | Finance
    7 | James | Finance

INNER JOIN

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

एक INNER JOIN, सबसे सामान्य प्रकार का जुड़ना है और जुड़ने का डिफ़ॉल्ट प्रकार है। आप वैकल्पिक रूप से INNER कीवर्ड का उपयोग कर सकते हैं।

निम्नलिखित ININ JOIN का वाक्य विन्यास है -

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

उपरोक्त सारणियों के आधार पर, हम निम्नानुसार एक INNER JOIN लिख सकते हैं -

testdb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
        ON COMPANY.ID = DEPARTMENT.EMP_ID;

ऊपर दी गई क्वेरी निम्न परिणाम देगी -

emp_id | name  | dept
--------+-------+------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering

बाईं ओर शामिल हैं

OUTER JOIN INNER JOIN का एक विस्तार है। SQL मानक तीन प्रकार के OUTER JOINs को परिभाषित करता है: LEFT, RIGHT, और FULL और PostgreSQL इन सभी का समर्थन करता है।

LEFT OUTER JOIN के मामले में, सबसे पहले एक आंतरिक जुड़ाव किया जाता है। फिर, तालिका T1 में प्रत्येक पंक्ति के लिए जो तालिका T2 में किसी पंक्ति के साथ जुड़ने की स्थिति को संतुष्ट नहीं करती है, एक सम्मिलित पंक्ति को T2 के स्तंभों में शून्य मानों के साथ जोड़ा जाता है। इस प्रकार, शामिल तालिका में हमेशा T1 में प्रत्येक पंक्ति के लिए कम से कम एक पंक्ति होती है।

निम्नलिखित LEFT OUTER JOIN का वाक्य विन्यास है -

SELECT ... FROM table1 LEFT OUTER JOIN table2 ON conditional_expression ...

उपरोक्त सारणियों के आधार पर, हम एक आंतरिक जुड़ाव निम्नानुसार लिख सकते हैं -

testdb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
   ON COMPANY.ID = DEPARTMENT.EMP_ID;

ऊपर दी गई क्वेरी निम्न परिणाम देगी -

emp_id | name  | dept
--------+-------+------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
        | James |
        | David |
        | Paul  |
        | Mark  |
        | Teddy |
        | James |

द राइट ऑप्टर जॉइन

सबसे पहले, एक आंतरिक जुड़ाव किया जाता है। फिर, तालिका T2 में प्रत्येक पंक्ति के लिए जो तालिका T1 में किसी पंक्ति के साथ जुड़ने की स्थिति को संतुष्ट नहीं करती है, एक सम्मिलित पंक्ति को T1 के कॉलम में शून्य मानों के साथ जोड़ा जाता है। यह लेफ्ट जॉइन का कायल है; परिणाम तालिका में हमेशा T2 में प्रत्येक पंक्ति के लिए एक पंक्ति होगी।

निम्नलिखित राइट जॉइन जॉय का वाक्य विन्यास है -

SELECT ... FROM table1 RIGHT OUTER JOIN table2 ON conditional_expression ...

उपरोक्त सारणियों के आधार पर, हम एक आंतरिक जुड़ाव निम्नानुसार लिख सकते हैं -

testdb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY RIGHT OUTER JOIN DEPARTMENT
   ON COMPANY.ID = DEPARTMENT.EMP_ID;

ऊपर दी गई क्वेरी निम्न परिणाम देगी -

emp_id | name  | dept
--------+-------+--------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 |       | Finance

फुल ऑवर जॉइन

सबसे पहले, एक आंतरिक जुड़ाव किया जाता है। फिर, तालिका T1 में प्रत्येक पंक्ति के लिए जो तालिका T2 में किसी पंक्ति के साथ जुड़ने की स्थिति को संतुष्ट नहीं करती है, एक सम्मिलित पंक्ति को T2 के स्तंभों में शून्य मानों के साथ जोड़ा जाता है। इसके अलावा, टी 2 की प्रत्येक पंक्ति के लिए जो टी 1 में किसी भी पंक्ति के साथ जुड़ने की स्थिति को संतुष्ट नहीं करता है, टी 1 के कॉलम में अशक्त मानों के साथ एक सम्मिलित पंक्ति को जोड़ा जाता है।

निम्नलिखित पूर्ण जूम का वाक्य विन्यास है -

SELECT ... FROM table1 FULL OUTER JOIN table2 ON conditional_expression ...

उपरोक्त सारणियों के आधार पर, हम एक आंतरिक जुड़ाव निम्नानुसार लिख सकते हैं -

testdb=# SELECT EMP_ID, NAME, DEPT FROM COMPANY FULL OUTER JOIN DEPARTMENT
   ON COMPANY.ID = DEPARTMENT.EMP_ID;

ऊपर दी गई क्वेरी निम्न परिणाम देगी -

emp_id | name  | dept
--------+-------+---------------
      1 | Paul  | IT Billing
      2 | Allen | Engineering
      7 |       | Finance
        | James |
        | David |
        | Paul  |
        | Mark  |
        | Teddy |
        | James |