SQLite - शामिल हैं

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

SQL तीन प्रमुख प्रकार के जॉइन को परिभाषित करता है -

  • क्रॉस जॉइन
  • INNER JOIN
  • OUTER JOIN

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

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

एक और तालिका निम्नलिखित परिभाषा के साथ विभाग है -

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

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

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY CROSS JOIN DEPARTMENT;

उपरोक्त क्वेरी निम्न परिणाम देगी -

EMP_ID      NAME        DEPT
----------  ----------  ----------
1           Paul        IT Billing
2           Paul        Engineering
7           Paul        Finance
1           Allen       IT Billing
2           Allen       Engineering
7           Allen       Finance
1           Teddy       IT Billing
2           Teddy       Engineering
7           Teddy       Finance
1           Mark        IT Billing
2           Mark        Engineering
7           Mark        Finance
1           David       IT Billing
2           David       Engineering
7           David       Finance
1           Kim         IT Billing
2           Kim         Engineering
7           Kim         Finance
1           James       IT Billing
2           James       Engineering
7           James       Finance

INNER JOIN

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

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

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

SELECT ... FROM table1 [INNER] JOIN table2 ON conditional_expression ...

अतिरेक से बचने और चेतावनियों को कम रखने के लिए, INNER JOIN स्थितियों को a के साथ घोषित किया जा सकता है USINGअभिव्यक्ति। यह अभिव्यक्ति एक या अधिक स्तंभों की सूची निर्दिष्ट करती है।

SELECT ... FROM table1 JOIN table2 USING ( column1 ,... ) ...

एक प्राकृतिक जोइन के समान है JOIN...USING, यह दोनों स्तंभों में मौजूद हर स्तंभ के मूल्यों के बीच समानता के लिए स्वचालित रूप से परीक्षण करता है -

SELECT ... FROM table1 NATURAL JOIN table2...

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

sqlite> 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
7           James       Finance

OUTER JOIN

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

OUTER JOINs में INNER JOIN के समान स्थिति होती है, जो ON, USING या NATURAL कीवर्ड का उपयोग करके व्यक्त की जाती है। प्रारंभिक परिणाम तालिका की गणना उसी तरह की जाती है। एक बार प्राथमिक JOIN की गणना हो जाने के बाद, एक OUTER JOIN एक या दोनों तालिकाओं से किसी भी असंबद्ध पंक्तियों को ले जाएगा, उन्हें NULLs के साथ पैड कर देगा, और उन्हें परिणामी तालिका में जोड़ देगा।

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

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

अतिरेक से बचने और चेतावनियों को कम रखने के लिए, OUTER JOIN स्थितियों को एक USING अभिव्यक्ति के साथ घोषित किया जा सकता है। यह अभिव्यक्ति एक या अधिक स्तंभों की सूची निर्दिष्ट करती है।

SELECT ... FROM table1 LEFT OUTER JOIN table2 USING ( column1 ,... ) ...

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

sqlite> 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
            Teddy
            Mark
            David
            Kim
7           James       Finance