aboutsummaryrefslogtreecommitdiffstats
path: root/yql/essentials/tests/s-expressions/suites/EquiJoin/EquiInnerCross3OptStr.yqls
blob: 9f014d1580fd06803608042a9b2d6f687e6f2022 (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
33
34
35
36
37
(
(let mr_source (DataSource 'yt 'plato))
(let x (Read! world mr_source (Key '('table (String 'Input1))) '('key 'subkey 'value) '()))
(let world (Left! x))
(let table1 (Right! x))
(let table1 (Map table1 (lambda '(item) (AsStruct
  '('key (Just (Member item 'key)))
  '('subkey (Just (Member item 'subkey)))
  '('value (Just (Member item 'value)))))))

(let x (Read! world mr_source (Key '('table (String 'Input2))) '('key 'subkey 'value) '()))
(let world (Left! x))
(let table2 (Right! x))

(let table2 (Map table2 (lambda '(item) (AsStruct
  '('key (Just (Member item 'key)))
  '('subkey (Just (Member item 'subkey)))
  '('value (Just (Member item 'value)))))))

(let x (Read! world mr_source (Key '('table (String 'Input3))) '('key 'subkey 'value) '()))
(let world (Left! x))
(let table3 (Right! x))

(let table3 (Map table3 (lambda '(item) (AsStruct
  '('key (Just (Member item 'key)))
  '('subkey (Just (Member item 'subkey)))
  '('value (Just (Member item 'value)))))))

(let join (EquiJoin '(table1 'a) '(table2 'b) '(table3 'c) 
  '('Inner
    '('Cross '"a" '"b" '() '() '()) 
    '"c" '('"a" '"key") '('"c" '"key") '()) '()))
(let res_sink (DataSink 'result))
(let world (Write! world res_sink (Key) join '('('type))))
(let world (Commit! world res_sink))
(return world)
)