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

क्वेरी अपने आप में एक ग्राहक तालिका में शामिल हो जाती है।