aboutsummaryrefslogtreecommitdiffstats
path: root/yql/essentials/tests/s-expressions/suites/Optimizers/FuseMapAfterLReduce.sql
blob: d3690a17e431ac6a79310654a8bb62699e0cb2e4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
USE plato;

$a = (SELECT
    skey,count(*) as cnt
FROM Input
GROUP BY Length(key) as skey);

$udfScript = @@
def f(input,x):
   for i in list(input):
      d = {name: getattr(i, name) for name in i.__class__.__match_args__}
      d["pass"] = x
      yield d
      
def f2(a,b,c):
   return {"a":a,"b":b,"c":c}
@@;

$udf = Python::f(@@
(Stream<Struct<skey:Uint32,cnt:Uint64>>,Int32)
->
Stream<Struct<skey:Uint32,cnt:Uint64,pass:Int32>>
@@, $udfScript);

$udf2 = Python::f2(@@
(skey:Uint32,cnt:Uint64,pass:Int32)->Struct<a:Uint32,b:Uint64,c:Int32>
@@, $udfScript);


$b = (PROCESS $a USING $udf($ROWS,1));

PROCESS $b USING $udf2(skey,cnt,pass);