Apache Tajo - SQL क्वेरीज़
यह अध्याय निम्नलिखित महत्वपूर्ण प्रश्नों के बारे में बताता है।
- Predicates
- Explain
- Join
आइए हम आगे बढ़ें और क्वेरी करें।
विधेय
विधेय एक अभिव्यक्ति है जिसका उपयोग सच्चे / झूठे मूल्यों और UNKNOWN के मूल्यांकन के लिए किया जाता है। विधेयकों का उपयोग WHERE क्लॉज़ और HAVING क्लॉज़ और अन्य निर्माणों की खोज स्थिति में किया जाता है जहाँ बूलियन मान आवश्यक है।
विधेय में
यह निर्धारित करता है कि परीक्षण के लिए अभिव्यक्ति का मूल्य उप-वर्ग या सूची में किसी भी मूल्य से मेल खाता है या नहीं। सबक्वेरी एक साधारण सेलेक्ट स्टेटमेंट है जिसमें एक कॉलम और एक या अधिक पंक्तियों का परिणाम सेट होता है। इस स्तंभ या सूची में सभी अभिव्यक्तियों के परीक्षण के लिए अभिव्यक्ति के समान डेटा प्रकार होना चाहिए।
Syntax
IN::=
<expression to test> [NOT] IN (<subquery>)
| (<expression1>,...)
Query
select id,name,address from mytable where id in(2,3,4);
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
id, name, address
-------------------------------
2, Amit, 12 old street
3, Bob, 10 cross street
4, David, 15 express avenue
क्वेरी से रिकॉर्ड देता है mytable छात्रों के लिए 2,3 और 4 आईडी।
Query
select id,name,address from mytable where id not in(2,3,4);
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
id, name, address
-------------------------------
1, Adam, 23 new street
5, Esha, 20 garden street
6, Ganga, 25 north street
7, Jack, 2 park street
8, Leena, 24 south street
9, Mary, 5 west street
10, Peter, 16 park avenue
उपरोक्त क्वेरी से रिकॉर्ड्स की वापसी होती है mytable जहां छात्र 2,3 और 4 में नहीं हैं।
जैसे प्रेडिक्ट करते हैं
LIKE विधेय को स्ट्रिंग मूल्य की गणना के लिए पहली अभिव्यक्ति में निर्दिष्ट स्ट्रिंग की तुलना करता है, जिसे परीक्षण के मान के रूप में संदर्भित किया जाता है, जो स्ट्रिंग मान की गणना के लिए दूसरी अभिव्यक्ति में परिभाषित पैटर्न के साथ है।
पैटर्न में वाइल्डकार्ड का कोई संयोजन हो सकता है जैसे कि -
अंडरलाइन प्रतीक (_), जिसका उपयोग परीक्षण के मूल्य में किसी एक वर्ण के बजाय किया जा सकता है।
प्रतिशत चिह्न (%), जो परीक्षण के मूल्य में शून्य या अधिक वर्णों के किसी भी स्ट्रिंग को प्रतिस्थापित करता है।
Syntax
LIKE::=
<expression for calculating the string value>
[NOT] LIKE
<expression for calculating the string value>
[ESCAPE <symbol>]
Query
select * from mytable where name like ‘A%';
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
id, name, address, age, mark
-------------------------------
1, Adam, 23 new street, 12, 90
2, Amit, 12 old street, 13, 95
क्वेरी उन छात्रों के mytable से रिकॉर्ड लौटाती है जिनके नाम 'A' से शुरू हो रहे हैं।
Query
select * from mytable where name like ‘_a%';
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
id, name, address, age, mark
——————————————————————————————————————-
4, David, 15 express avenue, 12, 85
6, Ganga, 25 north street, 12, 55
7, Jack, 2 park street, 12, 60
9, Mary, 5 west street, 12, 75
क्वेरी से रिकॉर्ड देता है mytable उन छात्रों के नाम जिनके नाम दूसरे चरण के रूप में 'ए' से शुरू हो रहे हैं।
खोज स्थितियों में NULL मान का उपयोग करना
आइए अब समझते हैं कि खोज स्थितियों में NULL मान का उपयोग कैसे करें।
Syntax
Predicate
IS [NOT] NULL
Query
select name from mytable where name is not null;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
name
-------------------------------
Adam
Amit
Bob
David
Esha
Ganga
Jack
Leena
Mary
Peter
(10 rows, 0.076 sec, 163 B selected)
यहां, परिणाम सही है, इसलिए यह तालिका से सभी नाम लौटाता है।
Query
चलिए अब NULL कंडीशन के साथ क्वेरी की जाँच करते हैं।
default> select name from mytable where name is null;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
name
-------------------------------
(0 rows, 0.068 sec, 0 B selected)
समझाना
Explainएक क्वेरी निष्पादन योजना प्राप्त करने के लिए उपयोग किया जाता है। यह एक बयान के तार्किक और वैश्विक योजना निष्पादन को दर्शाता है।
लॉजिकल प्लान क्वेरी
explain select * from mytable;
explain
-------------------------------
=> target list: default.mytable.id (INT4), default.mytable.name (TEXT),
default.mytable.address (TEXT), default.mytable.age (INT4), default.mytable.mark (INT4)
=> out schema: {
(5) default.mytable.id (INT4), default.mytable.name (TEXT), default.mytable.address (TEXT),
default.mytable.age (INT4), default.mytable.mark (INT4)
}
=> in schema: {
(5) default.mytable.id (INT4), default.mytable.name (TEXT), default.mytable.address (TEXT),
default.mytable.age (INT4), default.mytable.mark (INT4)
}
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
क्वेरी परिणाम दिए गए तालिका के लिए एक तार्किक योजना प्रारूप दिखाता है। तार्किक योजना निम्नलिखित तीन परिणाम लौटाती है -
- लक्ष्य सूची
- स्कीमा से बाहर
- स्कीमा में
वैश्विक योजना क्वेरी
explain global select * from mytable;
explain
-------------------------------
-------------------------------------------------------------------------------
Execution Block Graph (TERMINAL - eb_0000000000000_0000_000002)
-------------------------------------------------------------------------------
|-eb_0000000000000_0000_000002
|-eb_0000000000000_0000_000001
-------------------------------------------------------------------------------
Order of Execution
-------------------------------------------------------------------------------
1: eb_0000000000000_0000_000001
2: eb_0000000000000_0000_000002
-------------------------------------------------------------------------------
=======================================================
Block Id: eb_0000000000000_0000_000001 [ROOT]
=======================================================
SCAN(0) on default.mytable
=> target list: default.mytable.id (INT4), default.mytable.name (TEXT),
default.mytable.address (TEXT), default.mytable.age (INT4), default.mytable.mark (INT4)
=> out schema: {
(5) default.mytable.id (INT4), default.mytable.name (TEXT),default.mytable.address (TEXT),
default.mytable.age (INT4), default.mytable.mark (INT4)
}
=> in schema: {
(5) default.mytable.id (INT4), default.mytable.name (TEXT), default.mytable.address (TEXT),
default.mytable.age (INT4), default.mytable.mark (INT4)
}
=======================================================
Block Id: eb_0000000000000_0000_000002 [TERMINAL]
=======================================================
(24 rows, 0.065 sec, 0 B selected)
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
यहां, ग्लोबल प्लान निष्पादन ब्लॉक आईडी, निष्पादन का क्रम और इसकी जानकारी दिखाता है।
में शामिल
SQL जॉइन का उपयोग पंक्तियों को दो या अधिक तालिकाओं से संयोजित करने के लिए किया जाता है। निम्नलिखित SQL Joins के विभिन्न प्रकार हैं -
- आंतरिक रूप से जुड़ा
- {LEFT | राइट | पूर्ण} OUTER JOIN
- क्रॉस जॉइन करें
- स्वयं सम्मिलित हों
- प्राकृतिक जुड़ाव
जुड़ने के संचालन के लिए निम्नलिखित दो तालिकाओं पर विचार करें।
तालिका 1 - ग्राहक
ईद | नाम | पता | आयु |
---|---|---|---|
1 | ग्राहक 1 | 23 पुरानी सड़क | 21 |
2 | ग्राहक २ | 12 नई सड़क | 23 |
3 | ग्राहक ३ | 10 एक्सप्रेस एवेन्यू | 22 |
4 | ग्राहक ४ | 15 एक्सप्रेस एवेन्यू | 22 |
5 | ग्राहक ५ | 20 गार्डन स्ट्रीट | 33 |
6 | ग्राहक 6 | 21 उत्तर की सड़क | 25 |
Table2 - customer_order
ईद | आदेश ID | ईएम आईडी |
---|---|---|
1 | 1 | 101 |
2 | 2 | 102 |
3 | 3 | 103 |
4 | 4 | 104 |
5 | 5 | 105 |
अब हम आगे बढ़ते हैं और उपरोक्त दो टेबलों पर SQL ज्वाइन ऑपरेशन करते हैं।
आंतरिक रूप से जुड़ा
जब दोनों तालिकाओं में स्तंभों के बीच एक मेल होता है, तो इनर दोनों तालिकाओं से सभी पंक्तियों का चयन करता है।
Syntax
SELECT column_name(s) FROM table1 INNER JOIN table2 ON table1.column_name = table2.column_name;
Query
default> select c.age,c1.empid from customers c inner join customer_order c1 on c.id = c1.id;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
age, empid
-------------------------------
21, 101
23, 102
22, 103
22, 104
33, 105
क्वेरी दोनों तालिकाओं से पाँच पंक्तियों से मेल खाती है। इसलिए, यह पहली तालिका से मिलान की गई पंक्तियों की आयु लौटाता है।
बाईं ओर का बाहरी जोड़
एक बाएं बाहरी जुड़ाव "बाईं" तालिका की सभी पंक्तियों को बनाए रखता है, भले ही कोई पंक्ति "सही" तालिका पर मेल खाती हो या नहीं।
Query
select c.name,c1.empid from customers c left outer join customer_order c1 on c.id = c1.id;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
name, empid
-------------------------------
customer1, 101
customer2, 102
customer3, 103
customer4, 104
customer5, 105
customer6,
यहां, लेफ्ट आउटर में कस्टमर्स (लेफ्ट) टेबल से रिटर्न नेम कॉलम की पंक्तियों और कस्टमर कॉलम को कस्टमर_ऑर्डर (राईट) टेबल से पंक्तियों का मिलान किया जाता है।
राइट आउटर जॉइन करें
एक दाईं बाहरी जुड़ाव "दाईं" तालिका की सभी पंक्तियों को बनाए रखता है, भले ही कोई पंक्ति "बाईं" तालिका से मेल खाती हो।
Query
select c.name,c1.empid from customers c right outer join customer_order c1 on c.id = c1.id;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
name, empid
-------------------------------
customer1, 101
customer2, 102
customer3, 103
customer4, 104
customer5, 105
यहां, दायां बाहरी जोड़ ग्राहक_ऑर्डर (दाएं) तालिका से नाम पंक्तियों और ग्राहक तालिका से पंक्तियों के मिलान वाले नाम देता है।
पूर्ण बाहरी सम्मिलित हों
पूर्ण बाहरी जुड़ाव बाईं और दाईं तालिका से सभी पंक्तियों को बरकरार रखता है।
Query
select * from customers c full outer join customer_order c1 on c.id = c1.id;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
क्वेरी ग्राहकों और customer_order तालिकाओं से सभी मिलान और गैर-मिलान वाली पंक्तियाँ लौटाती है।
क्रॉस जॉइन करें
यह दो या अधिक सम्मिलित तालिकाओं से अभिलेखों के सेट का कार्टेशियन उत्पाद लौटाता है।
Syntax
SELECT * FROM table1 CROSS JOIN table2;
Query
select orderid,name,address from customers,customer_order;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
उपरोक्त क्वेरी तालिका का कार्टेशियन उत्पाद लौटाती है।
प्राकृतिक सम्मिलित हों
एक नेचुरल जॉइन किसी भी तुलना ऑपरेटर का उपयोग नहीं करता है। यह जिस तरह से एक कार्टेशियन उत्पाद करता है, उसे समाप्त नहीं करता है। हम केवल एक प्राकृतिक जुड़ाव का प्रदर्शन कर सकते हैं यदि कम से कम एक सामान्य विशेषता है जो दोनों संबंधों के बीच मौजूद है।
Syntax
SELECT * FROM table1 NATURAL JOIN table2;
Query
select * from customers natural join customer_order;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
यहां, एक सामान्य कॉलम आईडी है जो दो तालिकाओं के बीच मौजूद है। उस सामान्य कॉलम का उपयोग करते हुए,Natural Join दोनों तालिकाओं में मिलती है।
स्वयं सम्मिलित हों
SQL SELF JOIN का उपयोग किसी तालिका को स्वयं में शामिल करने के लिए किया जाता है जैसे कि तालिका दो तालिकाएँ थीं, अस्थायी रूप से SQL कथन में कम से कम एक तालिका का नाम बदलकर।
Syntax
SELECT a.column_name, b.column_name...
FROM table1 a, table1 b
WHERE a.common_filed = b.common_field
Query
default> select c.id,c1.name from customers c, customers c1 where c.id = c1.id;
Result
उपरोक्त क्वेरी निम्न परिणाम उत्पन्न करेगी।
id, name
-------------------------------
1, customer1
2, customer2
3, customer3
4, customer4
5, customer5
6, customer6
क्वेरी अपने आप में एक ग्राहक तालिका में शामिल हो जाती है।