SQLite - उपश्रेणियाँ

एक सबक्वेरी या इनर क्वेरी या नेस्टेड क्वेरी एक अन्य SQLite क्वेरी के भीतर एक क्वेरी है और WHERE क्लॉज के भीतर एम्बेडेड है।

एक सबक्वेरी का उपयोग डेटा को वापस करने के लिए किया जाता है जिसका उपयोग मुख्य क्वेरी में डेटा को पुनः प्राप्त करने के लिए प्रतिबंधित करने के लिए एक शर्त के रूप में किया जाएगा।

उप-प्रकार का उपयोग SELECT, INSERT, UPDATE, और DELETE कथनों के साथ किया जा सकता है जैसे ऑपरेटरों के साथ =, <,>,> = =, <=, IN, BETWEEN, आदि।

कुछ नियम हैं जिनका पालन करना होगा -

  • कोष्ठक के भीतर उप-विषयों को संलग्न किया जाना चाहिए।

  • सबक्लेरी का चयन खंड में केवल एक कॉलम हो सकता है, जब तक कि उसके चयनित कॉलम की तुलना करने के लिए सबक्वेरी में कई कॉलम मुख्य क्वेरी में न हों।

  • ORDER BY का उपयोग एक उपशम में नहीं किया जा सकता है, हालांकि मुख्य क्वेरी ORDER BY का उपयोग कर सकती है। ग्रुप BY का उपयोग एक उप-समारोह में ORDER BY के समान कार्य करने के लिए किया जा सकता है।

  • एक से अधिक पंक्ति में आने वाली उप-प्रक्रिया का उपयोग केवल कई मूल्य ऑपरेटरों जैसे IN ऑपरेटर के साथ किया जा सकता है।

  • BETWEEN ऑपरेटर का उपयोग एक उपश्रेणी के साथ नहीं किया जा सकता है; हालाँकि, BETWEEN का उपयोग उपकुंजी के भीतर किया जा सकता है।

चयन कथन के साथ उपश्रेणियाँ

सबक्वेरी का उपयोग अक्सर सेलेक्ट स्टेटमेंट के साथ किया जाता है। मूल वाक्य रचना इस प्रकार है -

SELECT column_name [, column_name ]
FROM table1 [, table2 ]
WHERE column_name OPERATOR
   (SELECT column_name [, column_name ]
      FROM table1 [, table2 ]
      [WHERE])

उदाहरण

निम्नलिखित रिकॉर्ड के साथ कंपनी की तालिका पर विचार करें ।

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

अब, हमें SELECT स्टेटमेंट के साथ निम्न सब-क्वेरी की जाँच करें।

sqlite> SELECT * 
   FROM COMPANY 
   WHERE ID IN (SELECT ID 
      FROM COMPANY 
      WHERE SALARY > 45000) ;

यह निम्नलिखित परिणाम का उत्पादन करेगा।

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0

INSERT वक्तव्य के साथ उपश्रेणियाँ

उपकेंद्रों का उपयोग INSERT के बयानों के साथ भी किया जा सकता है। INSERT विवरण उपकुंजी से लौटाए गए डेटा का उपयोग किसी अन्य तालिका में सम्मिलित करने के लिए करता है। उपकुंजी में चयनित डेटा को किसी भी चरित्र, दिनांक, या संख्या कार्यों के साथ संशोधित किया जा सकता है।

निम्नलिखित मूल सिंटैक्स निम्नानुसार है -

INSERT INTO table_name [ (column1 [, column2 ]) ]
   SELECT [ *|column1 [, column2 ]
   FROM table1 [, table2 ]
   [ WHERE VALUE OPERATOR ]

उदाहरण

किसी तालिका Company_BKP को कंपनी तालिका के समान संरचना के साथ विचार करें और तालिका नाम के रूप में Company_BKP का उपयोग करके उसी सृजन तालिका का उपयोग करके बनाया जा सकता है। पूरा कंपनी टेबल को Company_BKP में कॉपी करने के लिए, निम्नलिखित सिंटैक्स है -

sqlite> INSERT INTO COMPANY_BKP
   SELECT * FROM COMPANY 
   WHERE ID IN (SELECT ID 
      FROM COMPANY) ;

अद्यतन कथन के साथ उपश्रेणियाँ

उपखंड का उपयोग अद्यतन कथन के साथ किया जा सकता है। अद्यतन के साथ एक तालिका में एकल या एकाधिक स्तंभ अद्यतन किया जा सकता है जब अद्यतन कथन के साथ।

निम्नलिखित मूल सिंटैक्स निम्नानुसार है -

UPDATE table
SET column_name = new_value
[ WHERE OPERATOR [ VALUE ]
   (SELECT COLUMN_NAME
      FROM TABLE_NAME)
   [ WHERE) ]

उदाहरण

मान लें, हमारे पास Company_BKP तालिका उपलब्ध है जो कि कंपनी तालिका का एक बैकअप है।

उदाहरण के बाद, सभी ग्राहकों के लिए कंपनी की तालिका में सैलरी 0.50 गुना अपडेट होती है, जिसका AGE 27 से अधिक या उसके बराबर है।

sqlite> UPDATE COMPANY
   SET SALARY = SALARY * 0.50
   WHERE AGE IN (SELECT AGE FROM COMPANY_BKP
      WHERE AGE >= 27 );

यह दो पंक्तियों को प्रभावित करेगा और अंत में कंपनी तालिका में निम्नलिखित रिकॉर्ड होंगे -

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

DELETE कथन के साथ उपश्रेणियाँ

उपचेरी का उपयोग DELETE कथन के साथ संयोजन के रूप में किया जा सकता है जैसे कि ऊपर उल्लिखित किसी भी अन्य कथन के साथ।

निम्नलिखित मूल सिंटैक्स निम्नानुसार है -

DELETE FROM TABLE_NAME
[ WHERE OPERATOR [ VALUE ]
   (SELECT COLUMN_NAME
      FROM TABLE_NAME)
   [ WHERE) ]

उदाहरण

मान लें, हमारे पास Company_BKP तालिका उपलब्ध है जो कि कंपनी तालिका का एक बैकअप है।

निम्नलिखित उदाहरण उन सभी ग्राहकों के लिए कंपनी की तालिका से रिकॉर्ड हटा देता है, जिनका AGE 27 से अधिक या उसके बराबर है।

sqlite> DELETE FROM COMPANY
   WHERE AGE IN (SELECT AGE FROM COMPANY_BKP
   WHERE AGE > 27 );

यह दो पंक्तियों को प्रभावित करेगा और अंत में कंपनी तालिका में निम्नलिखित रिकॉर्ड होंगे -

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