课程表

Apache Pig 基础

Apache Pig 诊断运算符

Apache Pig 分组和连接

Apache Pig 合并和拆分

Apache Pig 过滤

Apache Pig 排序

Pig Latin 内置函数

Apache Pig 其他执行模式

工具箱
速查手册

Apache Pig DIFF()函数

当前位置:免费教程 » 大数据/云 » Apache Pig

Pig Latin的 DIFF() 函数用于比较元组中的两个包(字段)。它需要一个元组的两个字段作为输入并匹配它们。如果它们匹配,则返回一个空包。如果它们不匹配,它将找到存在于一个字段(包)中而在另一个字段中找不到的元素,并通过将它们打包进包中来返回这些元素。

语法

下面给出了 DIFF() 函数的语法。

  1. grunt> DIFF (expression, expression)

通常, DIFF() 函数比较元组中的两个包。下面是它的例子,这里我们创建两个关系,将它们cogroup,并计算它们之间的差异。假设在HDFS目录 /pig_data/ 中有两个文件,即 emp_sales.txt emp_bonus.txt ,如下所示。 emp_sales.txt 包含销售部门员工的详细信息, emp_bonus.txt 包含获得奖金的员工详细信息。

emp_sales.txt

  1. 1,Robin,22,25000,sales
  2. 2,BOB,23,30000,sales
  3. 3,Maya,23,25000,sales
  4. 4,Sara,25,40000,sales
  5. 5,David,23,45000,sales
  6. 6,Maggy,22,35000,sales

emp_bonus.txt

  1. 1,Robin,22,25000,sales
  2. 2,Jaya,23,20000,admin
  3. 3,Maya,23,25000,sales
  4. 4,Alia,25,50000,admin
  5. 5,David,23,45000,sales
  6. 6,Omar,30,30000,admin

分别使用关系 emp_sales  emp_bonus 将这些文件加载到Pig中。

  1. grunt> emp_sales = LOAD 'hdfs://localhost:9000/pig_data/emp_sales.txt' USING PigStorage(',')
  2. as (sno:int, name:chararray, age:int, salary:int, dept:chararray);
  3. grunt> emp_bonus = LOAD 'hdfs://localhost:9000/pig_data/emp_bonus.txt' USING PigStorage(',')
  4. as (sno:int, name:chararray, age:int, salary:int, dept:chararray);

使用COGROUP运算符和键 sno,将关系 emp_sales emp_bonus 的记录/元组分组,如下所示。

  1. grunt> cogroup_data = COGROUP emp_sales by sno, emp_bonus by sno;

使用 DUMP 运算符验证关系 cogroup_data ,如下所示。

  1. grunt> Dump cogroup_data;
  2. (1,{(1,Robin,22,25000,sales)},{(1,Robin,22,25000,sales)})
  3. (2,{(2,BOB,23,30000,sales)},{(2,Jaya,23,20000,admin)})
  4. (3,{(3,Maya,23,25000,sales)},{(3,Maya,23,25000,sales)})
  5. (4,{(4,Sara,25,40000,sales)},{(4,Alia,25,50000,admin)})
  6. (5,{(5,David,23,45000,sales)},{(5,David,23,45000,sales)})
  7. (6,{(6,Maggy,22,35000,sales)},{(6,Omar,30,30000,admin)})

计算两个关系之间的差异

现在让我们使用 DIFF() 函数计算两个关系之间的差异,并将其存储在关系 diff_data 中,如下所示。

  1. grunt> diff_data = FOREACH cogroup_data GENERATE DIFF(emp_sales,emp_bonus);

验证

使用DUMP运算符验证关系 diff_data ,如下所示。

  1. grunt> Dump diff_data;
  2. ({})
  3. ({(2,BOB,23,30000,sales),(2,Jaya,23,20000,admin)})
  4. ({})
  5. ({(4,Sara,25,40000,sales),(4,Alia,25,50000,admin)})
  6. ({})
  7. ({(6,Maggy,22,35000,sales),(6,Omar,30,30000,admin)})

如果 emp_bonus emp_sales 中的记录匹配,则 diff_data 关系将是空元组。在其他情况下,它将保存来自两个关系(不同的元组)的元组。

例如,如果将 sno 的记录视为 1 ,那么会发现它们在两个关系中都是相同的((1,Robin,22,25000,sales),(1,Robin,22,25000,sales))。因此,在 diff_data 关系中,将为 sno 1 得到一个空元组,它是 DIFF() 函数的结果

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号