Yield.sql 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /* syntax version 1 */
  2. SELECT YQL::@@(block '(
  3. (let vt (VariantType (TupleType (DataType 'String) (DataType 'String))))
  4. (let inputRows (AsList
  5. (Variant (String 'abbbbd111) '1 vt)
  6. (Variant (String 'btzzzzzzzzzz) '0 vt)
  7. (Variant (String 'kaziiaakkakaka) '1 vt)
  8. (Variant (String 'bufffffffff) '0 vt)
  9. (Variant (String 'aaaaa11111qqqqd) '1 vt)
  10. (Variant (String 'zoppppppppp) '0 vt)
  11. (Variant (String 'arrrrrrrr) '0 vt)
  12. (Variant (String 'zzzzzzzzzzzzzzz) '0 vt)
  13. (Variant (String 'wwwwwwwwwwwwwww1) '0 vt)
  14. (Variant (String 'baaaaaaaaaaaaaaa) '1 vt)
  15. ))
  16. (let udf (Udf '"Streaming.Process"))
  17. (let args1 (AsList (String '"[ab1]")))
  18. (let args2 (AsList (String '"[rpd]")))
  19. (let pr (lambda '(x) (block '(
  20. (let res (AsStruct '('Data x)))
  21. (return res)
  22. ))))
  23. (let tr1 (lambda '(x) (block '(
  24. (let y (OrderedMap x pr))
  25. (return (Apply udf y (String '"grep") args1)))
  26. )))
  27. (let tr2 (lambda '(x) (block '(
  28. (let y (OrderedMap x pr))
  29. (return (Apply udf y (String '"grep") args2)))
  30. )))
  31. (let id (lambda '(x) x))
  32. (let res1 (Switch (Iterator inputRows (DependsOn (String 'A))) '1 '('0) tr1 '('1) tr2))
  33. (let pr2 (lambda '(x) (Member x 'Data)))
  34. (let pr3 (lambda '(x) (Visit x '0 pr2 '1 pr2)))
  35. (let res2 (OrderedMap (Collect res1) pr3))
  36. (let res3 (Sort res2 (Bool 'true) id))
  37. (return res3)
  38. ))@@;