Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Gruppen-Concat-Äquivalent in Schwein?

grouped = GROUP table BY userid;
   X = FOREACH grouped GENERATE group as userid, 
                                table.clickcount as clicksbag, 
                                table.pagenumber as pagenumberbag;

Jetzt X wird sein:

{(155,{(2),(3),(1)},{(12),(133),(144)},
 (156,{(6),(7)},{(1),(5)}}

Jetzt müssen Sie den builtin verwenden UDF BagToTuple :

output = FOREACH X GENERATE userid, 
                            BagToTuple(clickbag) as clickcounts, 
                            BagToTuple(pagenumberbag) as pagenumbers;

output sollte jetzt enthalten, was Sie wollen. Sie können den Ausgabeschritt auch mit dem Zusammenführungsschritt zusammenführen:

    output = FOREACH grouped GENERATE group as userid, 
                     BagToTuple(table.clickcount) as clickcounts, 
                     BagToTuple(table.pagenumber) as pagenumbers;