PostgreSQL - उप क्वेरी

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

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

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

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

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

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

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

  • एक से अधिक पंक्ति में लौटने वाली उप-श्रेणियों का उपयोग केवल कई मान ऑपरेटरों, जैसे IN, EXISTS, NOT IN, किसी / SOME, सभी ऑपरेटर के साथ किया जा सकता है।

  • 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
  2 | Allen |  25 | Texas     |  15000
  3 | Teddy |  23 | Norway    |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas     |  85000
  6 | Kim   |  22 | South-Hall|  45000
  7 | James |  24 | Houston   |  10000
(7 rows)

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

testdb=# SELECT *
   FROM COMPANY
   WHERE ID IN (SELECT ID
      FROM COMPANY
      WHERE SALARY > 45000) ;

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

id | name  | age |  address    | salary
----+-------+-----+-------------+--------
  4 | Mark  |  25 | Rich-Mond   |  65000
  5 | David |  27 | Texas       |  85000
(2 rows)

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

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

मूल वाक्य रचना इस प्रकार है -

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

उदाहरण

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

testdb=# 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 से अधिक या उसके बराबर है -

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

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

id | name  | age | address     | salary
----+-------+-----+-------------+--------
  2 | Allen |  25 | Texas       |  15000
  3 | Teddy |  23 | Norway      |  20000
  4 | Mark  |  25 | Rich-Mond   |  65000
  6 | Kim   |  22 | South-Hall  |  45000
  7 | James |  24 | Houston     |  10000
  1 | Paul  |  32 | California  |  10000
  5 | David |  27 | Texas       |  42500
(7 rows)

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

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

मूल वाक्य रचना इस प्रकार है -

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

उदाहरण

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

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

testdb=# DELETE FROM COMPANY
   WHERE AGE IN (SELECT AGE FROM COMPANY_BKP
      WHERE AGE > 27 );

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

id | name  | age | address     | salary
----+-------+-----+-------------+--------
  2 | Allen |  25 | Texas       |  15000
  3 | Teddy |  23 | Norway      |  20000
  4 | Mark  |  25 | Rich-Mond   |  65000
  6 | Kim   |  22 | South-Hall  |  45000
  7 | James |  24 | Houston     |  10000
  5 | David |  27 | Texas       |  42500
(6 rows)