the cross operator computes the cross-product of two or more relations. this chapter explains with example how to use the cross operator in pig latin.
syntax
given below is the syntax of the cross operator.
grunt> relation3_name = cross relation1_name, relation2_name;
example
assume that we have two files namely customers.txt and orders.txt in the /pig_data/ directory of hdfs as shown below.
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
and we have loaded these two files into pig with the relations customers and orders as shown below.
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);
let us now get the cross-product of these two relations using the cross operator on these two relations as shown below.
grunt> cross_data = cross customers, orders;
verification
verify the relation cross_data using the dump operator as shown below.
grunt> dump cross_data;
output
it will produce the following output, displaying the contents of the relation cross_data.
(7,muffy,24,indore,10000,103,2008-05-20 00:00:00,4,2060) (7,muffy,24,indore,10000,101,2009-11-20 00:00:00,2,1560) (7,muffy,24,indore,10000,100,2009-10-08 00:00:00,3,1500) (7,muffy,24,indore,10000,102,2009-10-08 00:00:00,3,3000) (6,komal,22,mp,4500,103,2008-05-20 00:00:00,4,2060) (6,komal,22,mp,4500,101,2009-11-20 00:00:00,2,1560) (6,komal,22,mp,4500,100,2009-10-08 00:00:00,3,1500) (6,komal,22,mp,4500,102,2009-10-08 00:00:00,3,3000) (5,hardik,27,bhopal,8500,103,2008-05-20 00:00:00,4,2060) (5,hardik,27,bhopal,8500,101,2009-11-20 00:00:00,2,1560) (5,hardik,27,bhopal,8500,100,2009-10-08 00:00:00,3,1500) (5,hardik,27,bhopal,8500,102,2009-10-08 00:00:00,3,3000) (4,chaitali,25,mumbai,6500,103,2008-05-20 00:00:00,4,2060) (4,chaitali,25,mumbai,6500,101,2009-20 00:00:00,4,2060) (2,khilan,25,delhi,1500,101,2009-11-20 00:00:00,2,1560) (2,khilan,25,delhi,1500,100,2009-10-08 00:00:00,3,1500) (2,khilan,25,delhi,1500,102,2009-10-08 00:00:00,3,3000) (1,ramesh,32,ahmedabad,2000,103,2008-05-20 00:00:00,4,2060) (1,ramesh,32,ahmedabad,2000,101,2009-11-20 00:00:00,2,1560) (1,ramesh,32,ahmedabad,2000,100,2009-10-08 00:00:00,3,1500) (1,ramesh,32,ahmedabad,2000,102,2009-10-08 00:00:00,3,3000)-11-20 00:00:00,2,1560) (4,chaitali,25,mumbai,6500,100,2009-10-08 00:00:00,3,1500) (4,chaitali,25,mumbai,6500,102,2009-10-08 00:00:00,3,3000) (3,kaushik,23,kota,2000,103,2008-05-20 00:00:00,4,2060) (3,kaushik,23,kota,2000,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) (2,khilan,25,delhi,1500,103,2008-05-20 00:00:00,4,2060) (2,khilan,25,delhi,1500,101,2009-11-20 00:00:00,2,1560) (2,khilan,25,delhi,1500,100,2009-10-08 00:00:00,3,1500) (2,khilan,25,delhi,1500,102,2009-10-08 00:00:00,3,3000) (1,ramesh,32,ahmedabad,2000,103,2008-05-20 00:00:00,4,2060) (1,ramesh,32,ahmedabad,2000,101,2009-11-20 00:00:00,2,1560) (1,ramesh,32,ahmedabad,2000,100,2009-10-08 00:00:00,3,1500) (1,ramesh,32,ahmedabad,2000,102,2009-10-08 00:00:00,3,3000)