gpt4 book ai didi

hadoop - 使用 cassandra 和 pig 进行数据清理

转载 作者:可可西里 更新时间:2023-11-01 15:18:17 25 4
gpt4 key购买 nike

我有两组数据想在 Pig 中进行比较。两者具有相同的唯一 ID,但第二组数据中的名称随机更改。逻辑如下:

  • 加载empl1原始数据
  • 加载empl2原始数据
  • 选择“名称不相同”且“emplno 相等”的行

我做了:

A1=  LOAD 'cassandra://employees_pig1/employees_cf' USING CassandraStorage() AS (key, columns: bag {T: tuple(name, value)});

B1= LOAD 'cassandra://employees_pig2/employees_cf' USING CassandraStorage() AS (key, columns: bag {T: tuple(name, value)});

A2 = FOREACH A1 GENERATE key, FLATTEN(columns);

B2 = FOREACH B1 GENERATE key as key2, FLATTEN(columns);

嘿,不能在论坛上发图片。这是说明 A2,B2 的链接 https://picasaweb.google.com/lh/photo/SU3QgKsbA4nmq83cdnhiVdMTjNZETYmyPJy0liipFm0?feat=directlink

现在需要一些帮助,我是否正确地处理了这个问题?

C1 = join A2 by key, B2 by key2;

D1= filter C1 by A2.key==B2.key2 -- cannot do a A2.first_name!=B2.first_name;

想要选择“名称不相同”和“emplno 相等”的行,但不完全确定如何操作。请告知。

谢谢你

更新:- 而不是加入我做了一个合作组 C3= COGROUP A2 by key, B2 by key2;

https://picasaweb.google.com/lh/photo/_lkEqW4BvIgbnZSHKDCJGNMTjNZETYmyPJy0liipFm0?feat=directlink

下一步,我正在考虑做

D1= FOREACH C3 GENERATE group, A2.first_name as fn1, B2.first_name as fn2

该组返回所需的结果(即 empno),但 'A2.first_name, B2.first_name' 不正确。需要知道如何访问 A2 和 B2 包/元组中的数据。

然后我将能够执行 FILTER BY fn1==fn2。

最佳答案

通过执行 JOIN(至少是内部联接,这是您在上面所做的),您已经注意确保 emplno 来自 AB 是相等的。然后,您所要做的就是根据 name 是否相同进行过滤。

C1 = join A2 by key, B2 by key;
D1 = filter C1 by A2::name != B2::name;

关于hadoop - 使用 cassandra 和 pig 进行数据清理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13604024/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com