टी-एसक्यूएल - उप-प्रश्न

sub-query या Inner query या Nested queryएक अन्य SQL सर्वर क्वेरी के भीतर एक क्वेरी है और WHERE क्लॉज के भीतर एम्बेडेड है। डेटा वापस करने के लिए एक उप क्वेरी का उपयोग किया जाता है जो मुख्य क्वेरी में डेटा को पुनः प्राप्त करने के लिए प्रतिबंधित करने के लिए एक शर्त के रूप में उपयोग किया जाएगा।

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

कुछ नियम हैं जो उप प्रश्नों का पालन करना चाहिए -

  • आपको कोष्ठक में एक उपशम को जोड़ना होगा।

  • एक उपवर्ग में एक सेलेक्ट क्लॉज और एक FROM क्लॉज शामिल होना चाहिए।

  • एक उपश्रेणी में वैकल्पिक WHERE, GROUP BY और HAVING खंड शामिल हो सकते हैं।

  • एक उपश्रेणी COMPUTE या BROWSE क्लॉस में शामिल नहीं हो सकती।

  • आप ORDER BY क्लॉज़ को केवल तभी शामिल कर सकते हैं जब कोई TOP क्लॉज़ शामिल हो।

  • आप 32 स्तरों तक उप प्रश्नों को घोंसला बना सकते हैं।

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

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

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

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

हमें सेलेक्ट स्टेटमेंट के साथ निम्नलिखित सबक्विरी लागू करते हैं।

SELECT *  
   FROM CUSTOMERS
   WHERE ID IN (SELECT ID FROM CUSTOMERS WHERE SALARY > 4500)

उपरोक्त आदेश निम्नलिखित आउटपुट का उत्पादन करेगा।

ID  NAME       AGE       ADDRESS          SALARY 
4   Chaitali   25        Mumbai           6500.00 
5   Hardik     27        Bhopal           8500.00 
7   Muffy      24        Indore           10000.00

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

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

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

निम्नलिखित मूल सिंटैक्स है।

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

उदाहरण

एक तालिका CUSTOMERS_BKP पर विचार करें जैसे CUSTOMERS तालिका के समान संरचना। CUSTOMERS_BKP में पूरा कस्टमर टेबल कॉपी करने का सिंटैक्स निम्नलिखित है।

INSERT INTO CUSTOMERS_BKP 
   SELECT * FROM CUSTOMERS  
   WHERE ID IN (SELECT ID FROM CUSTOMERS)

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

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

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

निम्नलिखित मूल सिंटैक्स है।

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

उदाहरण

मान लें कि हमारे पास CUSTOMERS_BKP तालिका उपलब्ध है जो CUSTOMERS तालिका का बैकअप है।

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

UPDATE CUSTOMERS 
   SET SALARY = SALARY * 0.25 
   WHERE AGE IN (SELECT AGE FROM CUSTOMERS_BKP WHERE AGE >= 27 )

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

ID  NAME       AGE       ADDRESS             SALARY 
1   Ramesh     32        Ahmedabad           500.00 
2   Khilan     25        Delhi               1500.00 
3   kaushik    23        Kota                2000.00 
4   Chaitali   25        Mumbai              6500.00 
5   Hardik     27        Bhopal              2125.00 
6   Komal      22        MP                  4500.00 
7   Muffy      24        Indore              10000.00

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

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

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

निम्नलिखित मूल सिंटैक्स है।

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

उदाहरण

मान लें कि हमारे पास CUSTOMERS_BKP तालिका उपलब्ध है जो CUSTOMERS तालिका का बैकअप है।

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

DELETE FROM CUSTOMERS 
   WHERE AGE IN (SELECT AGE FROM CUSTOMERS_BKP WHERE AGE >=27 )

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

ID  NAME       AGE       ADDRESS          SALARY 
2   Khilan     25        Delhi            1500.00 
3   kaushik    23        Kota             2000.00 
4   Chaitali   25        Mumbai           6500.00  
6   Komal      22        MP               4500.00 
7   Muffy      24        Indore           10000.00