Apache Pig - संचालक से जुड़ें
JOINऑपरेटर का उपयोग दो या अधिक संबंधों के रिकॉर्ड को संयोजित करने के लिए किया जाता है। ज्वाइन ऑपरेशन करते समय, हम प्रत्येक संबंध से एक (या एक समूह) टपल की घोषणा करते हैं, कुंजी के रूप में। जब ये चाबियां मेल खाती हैं, तो दो विशेष ट्यूपल्स का मिलान किया जाता है, अन्यथा रिकॉर्ड गिरा दिए जाते हैं। जॉइन निम्न प्रकार के हो सकते हैं -
- Self-join
- Inner-join
- आउटर-जॉइन - लेफ्ट जॉइन, राइट जॉइन और फुल जॉइन
यह अध्याय उदाहरणों के साथ बताता है कि पिग लैटिन में शामिल ऑपरेटर का उपयोग कैसे करें। मान लें कि हमारे पास दो फाइलें हैंcustomers.txt तथा orders.txt में /pig_data/ नीचे दिखाए गए अनुसार HDFS की निर्देशिका।
customers.txt
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
orders.txt
102,2009-10-08 00:00:00,3,3000
100,2009-10-08 00:00:00,3,1500
101,2009-11-20 00:00:00,2,1560
103,2008-05-20 00:00:00,4,2060
और हमने इन दो फाइलों को संबंधों के साथ पिग में लोड किया है customers तथा orders जैसा की नीचे दिखाया गया।
grunt> customers = LOAD 'hdfs://localhost:9000/pig_data/customers.txt' USING PigStorage(',')
as (id:int, name:chararray, age:int, address:chararray, salary:int);
grunt> orders = LOAD 'hdfs://localhost:9000/pig_data/orders.txt' USING PigStorage(',')
as (oid:int, date:chararray, customer_id:int, amount:int);
आइए अब हम इन दोनों संबंधों पर विभिन्न जॉइन ऑपरेशन्स करते हैं।
स्व - जुड़ना
Self-join अपने आप से एक तालिका में शामिल होने के लिए उपयोग किया जाता है जैसे कि तालिका दो संबंध थे, अस्थायी रूप से कम से कम एक संबंध का नाम बदलकर।
आमतौर पर, अपाचे सुअर में, स्व-शामिल होने के लिए, हम अलग-अलग उपनाम (नामों) के तहत एक ही डेटा को कई बार लोड करेंगे। इसलिए हमें फ़ाइल की सामग्री लोड करने देंcustomers.txt नीचे दिखाए गए अनुसार दो तालिकाओं के रूप में।
grunt> customers1 = LOAD 'hdfs://localhost:9000/pig_data/customers.txt' USING PigStorage(',')
as (id:int, name:chararray, age:int, address:chararray, salary:int);
grunt> customers2 = LOAD 'hdfs://localhost:9000/pig_data/customers.txt' USING PigStorage(',')
as (id:int, name:chararray, age:int, address:chararray, salary:int);
वाक्य - विन्यास
नीचे दिए गए प्रदर्शन का वाक्यविन्यास है self-join ऑपरेशन का उपयोग कर JOIN ऑपरेटर।
grunt> Relation3_name = JOIN Relation1_name BY key, Relation2_name BY key ;
उदाहरण
हम प्रदर्शन करते हैं self-join संबंध पर संचालन customers, दो संबंधों में शामिल होने से customers1 तथा customers2 जैसा की नीचे दिखाया गया।
grunt> customers3 = JOIN customers1 BY id, customers2 BY id;
सत्यापन
संबंध सत्यापित करें customers3 का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> Dump customers3;
उत्पादन
यह निम्नलिखित आउटपुट का उत्पादन करेगा, जो संबंध की सामग्री को प्रदर्शित करेगा customers।
(1,Ramesh,32,Ahmedabad,2000,1,Ramesh,32,Ahmedabad,2000)
(2,Khilan,25,Delhi,1500,2,Khilan,25,Delhi,1500)
(3,kaushik,23,Kota,2000,3,kaushik,23,Kota,2000)
(4,Chaitali,25,Mumbai,6500,4,Chaitali,25,Mumbai,6500)
(5,Hardik,27,Bhopal,8500,5,Hardik,27,Bhopal,8500)
(6,Komal,22,MP,4500,6,Komal,22,MP,4500)
(7,Muffy,24,Indore,10000,7,Muffy,24,Indore,10000)
आंतरिक रूप से जुड़ा
Inner Joinअक्सर इस्तेमाल किया जाता है; यह भी कहा जाता हैequijoin। जब दोनों तालिकाओं में मैच होता है, तो एक आंतरिक जुड़ाव पंक्तियों को जोड़ता है।
यह दो संबंध (ए और बी) के स्तंभ मानों को जोड़कर एक नया संबंध बनाता है, जो कि संयुक्त-विधेय पर आधारित है। क्वेरी बी के प्रत्येक पंक्ति के साथ A की प्रत्येक पंक्ति की तुलना उन सभी जोड़ियों को खोजने के लिए करती है जो जॉइन-प्रेडिकेट को संतुष्ट करते हैं। जब जॉइन-प्रेडिकेट संतुष्ट हो जाता है, तो ए और बी की पंक्तियों के प्रत्येक मिलान किए गए जोड़े के लिए कॉलम वैल्यू को एक परिणाम पंक्ति में जोड़ दिया जाता है।
वाक्य - विन्यास
यहाँ प्रदर्शन का वाक्य विन्यास है inner join ऑपरेशन का उपयोग कर JOIN ऑपरेटर।
grunt> result = JOIN relation1 BY columnname, relation2 BY columnname;
उदाहरण
हम प्रदर्शन करते हैं inner join दो संबंधों पर संचालन customers तथा orders जैसा की नीचे दिखाया गया।
grunt> coustomer_orders = JOIN customers BY id, orders BY customer_id;
सत्यापन
संबंध सत्यापित करें coustomer_orders का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> Dump coustomer_orders;
उत्पादन
आपको निम्न आउटपुट मिलेंगे जो नाम के संबंध की सामग्री होगी coustomer_orders।
(2,Khilan,25,Delhi,1500,101,2009-11-20 00:00:00,2,1560)
(3,kaushik,23,Kota,2000,100,2009-10-08 00:00:00,3,1500)
(3,kaushik,23,Kota,2000,102,2009-10-08 00:00:00,3,3000)
(4,Chaitali,25,Mumbai,6500,103,2008-05-20 00:00:00,4,2060)
Note -
बाहरी जुड़ाव : भीतरी जुड़ाव के विपरीत,outer joinकम से कम संबंधों में से सभी पंक्तियों को लौटाता है। एक बाहरी जुड़ाव ऑपरेशन तीन तरीकों से किया जाता है -
- बाईं ओर का बाहरी जोड़
- सही बाहरी जुड़ना
- पूर्ण बाहरी जुड़ना
बाईं ओर का बाहरी जोड़
left outer Join ऑपरेशन बाईं पंक्ति से सभी पंक्तियों को लौटाता है, भले ही सही संबंध में कोई मेल न हो।
वाक्य - विन्यास
नीचे दिए गए प्रदर्शन का वाक्यविन्यास है left outer join ऑपरेशन का उपयोग कर JOIN ऑपरेटर।
grunt> Relation3_name = JOIN Relation1_name BY id LEFT OUTER, Relation2_name BY customer_id;
उदाहरण
हमें नीचे दिखाए गए अनुसार दो रिलेशनशिप कस्टमर्स और ऑर्डर पर लेफ्ट ऑउट ज्वाइन ऑपरेशन करना है।
grunt> outer_left = JOIN customers BY id LEFT OUTER, orders BY customer_id;
सत्यापन
संबंध सत्यापित करें outer_left का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> Dump outer_left;
उत्पादन
यह निम्नलिखित आउटपुट का उत्पादन करेगा, जो संबंध की सामग्री को प्रदर्शित करेगा outer_left।
(1,Ramesh,32,Ahmedabad,2000,,,,)
(2,Khilan,25,Delhi,1500,101,2009-11-20 00:00:00,2,1560)
(3,kaushik,23,Kota,2000,100,2009-10-08 00:00:00,3,1500)
(3,kaushik,23,Kota,2000,102,2009-10-08 00:00:00,3,3000)
(4,Chaitali,25,Mumbai,6500,103,2008-05-20 00:00:00,4,2060)
(5,Hardik,27,Bhopal,8500,,,,)
(6,Komal,22,MP,4500,,,,)
(7,Muffy,24,Indore,10000,,,,)
राइट आउटर जॉइन करें
right outer join ऑपरेशन सही तालिका से सभी पंक्तियों को लौटाता है, भले ही बाईं तालिका में कोई मिलान न हो।
वाक्य - विन्यास
नीचे दिए गए प्रदर्शन का वाक्यविन्यास है right outer join ऑपरेशन का उपयोग कर JOIN ऑपरेटर।
grunt> outer_right = JOIN customers BY id RIGHT, orders BY customer_id;
उदाहरण
हम प्रदर्शन करते हैं right outer join दो संबंधों पर संचालन customers तथा orders जैसा की नीचे दिखाया गया।
grunt> outer_right = JOIN customers BY id RIGHT, orders BY customer_id;
सत्यापन
संबंध सत्यापित करें outer_right का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> Dump outer_right
उत्पादन
यह निम्नलिखित आउटपुट का उत्पादन करेगा, जो संबंध की सामग्री को प्रदर्शित करेगा outer_right।
(2,Khilan,25,Delhi,1500,101,2009-11-20 00:00:00,2,1560)
(3,kaushik,23,Kota,2000,100,2009-10-08 00:00:00,3,1500)
(3,kaushik,23,Kota,2000,102,2009-10-08 00:00:00,3,3000)
(4,Chaitali,25,Mumbai,6500,103,2008-05-20 00:00:00,4,2060)
पूर्ण बाहरी सम्मिलित हों
full outer join जब किसी एक संबंध में मैच होता है तो ऑपरेशन रिटर्न पंक्तियां देता है।
वाक्य - विन्यास
नीचे दिए गए प्रदर्शन का वाक्यविन्यास है full outer join का उपयोग करते हुए JOIN ऑपरेटर।
grunt> outer_full = JOIN customers BY id FULL OUTER, orders BY customer_id;
उदाहरण
हम प्रदर्शन करते हैं full outer join दो संबंधों पर संचालन customers तथा orders जैसा की नीचे दिखाया गया।
grunt> outer_full = JOIN customers BY id FULL OUTER, orders BY customer_id;
सत्यापन
संबंध सत्यापित करें outer_full का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grun> Dump outer_full;
उत्पादन
यह निम्नलिखित आउटपुट का उत्पादन करेगा, जो संबंध की सामग्री को प्रदर्शित करेगा outer_full।
(1,Ramesh,32,Ahmedabad,2000,,,,)
(2,Khilan,25,Delhi,1500,101,2009-11-20 00:00:00,2,1560)
(3,kaushik,23,Kota,2000,100,2009-10-08 00:00:00,3,1500)
(3,kaushik,23,Kota,2000,102,2009-10-08 00:00:00,3,3000)
(4,Chaitali,25,Mumbai,6500,103,2008-05-20 00:00:00,4,2060)
(5,Hardik,27,Bhopal,8500,,,,)
(6,Komal,22,MP,4500,,,,)
(7,Muffy,24,Indore,10000,,,,)
एकाधिक कुंजी का उपयोग करना
हम कई कुंजियों का उपयोग करके JOIN ऑपरेशन कर सकते हैं।
वाक्य - विन्यास
यहां बताया गया है कि आप कई कुंजियों का उपयोग करके दो टेबलों पर जॉय ऑपरेशन कैसे कर सकते हैं।
grunt> Relation3_name = JOIN Relation2_name BY (key1, key2), Relation3_name BY (key1, key2);
मान लें कि हमारे पास दो फाइलें हैं employee.txt तथा employee_contact.txt में /pig_data/ नीचे दिखाए गए अनुसार HDFS की निर्देशिका।
employee.txt
001,Rajiv,Reddy,21,programmer,003
002,siddarth,Battacharya,22,programmer,003
003,Rajesh,Khanna,22,programmer,003
004,Preethi,Agarwal,21,programmer,003
005,Trupthi,Mohanthy,23,programmer,003
006,Archana,Mishra,23,programmer,003
007,Komal,Nayak,24,teamlead,002
008,Bharathi,Nambiayar,24,manager,001
employee_contact.txt
001,9848022337,[email protected],Hyderabad,003
002,9848022338,[email protected],Kolkata,003
003,9848022339,[email protected],Delhi,003
004,9848022330,[email protected],Pune,003
005,9848022336,[email protected],Bhuwaneshwar,003
006,9848022335,[email protected],Chennai,003
007,9848022334,[email protected],trivendram,002
008,9848022333,[email protected],Chennai,001
और हमने इन दो फाइलों को संबंधों के साथ सुअर में लोड किया है employee तथा employee_contact जैसा की नीचे दिखाया गया।
grunt> employee = LOAD 'hdfs://localhost:9000/pig_data/employee.txt' USING PigStorage(',')
as (id:int, firstname:chararray, lastname:chararray, age:int, designation:chararray, jobid:int);
grunt> employee_contact = LOAD 'hdfs://localhost:9000/pig_data/employee_contact.txt' USING PigStorage(',')
as (id:int, phone:chararray, email:chararray, city:chararray, jobid:int);
अब, हम इन दो संबंधों की सामग्री का उपयोग करते हुए जुड़ते हैं JOIN ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> emp = JOIN employee BY (id,jobid), employee_contact BY (id,jobid);
सत्यापन
संबंध सत्यापित करें emp का उपयोग करते हुए DUMP ऑपरेटर जैसा कि नीचे दिखाया गया है।
grunt> Dump emp;
उत्पादन
यह निम्नलिखित आउटपुट का उत्पादन करेगा, नाम के संबंध की सामग्री प्रदर्शित करेगा emp जैसा की नीचे दिखाया गया।
(1,Rajiv,Reddy,21,programmer,113,1,9848022337,[email protected],Hyderabad,113)
(2,siddarth,Battacharya,22,programmer,113,2,9848022338,[email protected],Kolka ta,113)
(3,Rajesh,Khanna,22,programmer,113,3,9848022339,[email protected],Delhi,113)
(4,Preethi,Agarwal,21,programmer,113,4,9848022330,[email protected],Pune,113)
(5,Trupthi,Mohanthy,23,programmer,113,5,9848022336,[email protected],Bhuwaneshw ar,113)
(6,Archana,Mishra,23,programmer,113,6,9848022335,[email protected],Chennai,113)
(7,Komal,Nayak,24,teamlead,112,7,9848022334,[email protected],trivendram,112)
(8,Bharathi,Nambiayar,24,manager,111,8,9848022333,[email protected],Chennai,111)