YieldSwitchEmpty.sql 1.3 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 'aaaaaa) '0 vt)
  6. (Variant (String 'bbbbbb) '1 vt)
  7. (Variant (String 'aaaaaa) '0 vt)
  8. (Variant (String 'bbbbbb) '1 vt)
  9. (Variant (String 'aaaaaa) '0 vt)
  10. (Variant (String 'bbbbbb) '1 vt)
  11. (Variant (String 'aaaaaa) '0 vt)
  12. (Variant (String 'bbbbbb) '1 vt)
  13. (Variant (String 'aaaaaa) '0 vt)
  14. (Variant (String 'bbbbbb) '1 vt)
  15. (Variant (String 'aaaaaa) '0 vt)
  16. (Variant (String 'bbbbbb) '1 vt)
  17. (Variant (String 'aaaaaa) '0 vt)
  18. (Variant (String 'bbbbbb) '1 vt)
  19. (Variant (String 'aaaaaa) '0 vt)
  20. (Variant (String 'bbbbbb) '1 vt)
  21. ))
  22. (let udf (Udf '"Streaming.Process"))
  23. (let args (AsList (String '"-c") (String '"grep missing || true")))
  24. (let pr (lambda '(x) (block '(
  25. (let res (AsStruct '('Data x)))
  26. (return res)
  27. ))))
  28. (let tr1 (lambda '(x) (block '(
  29. (let y (Map x pr))
  30. (return (Apply udf y (String '"bash") args)))
  31. )))
  32. (let tr2 (lambda '(x) (block '(
  33. (let y (Map x pr))
  34. (return (Apply udf y (String '"bash") args)))
  35. )))
  36. (let input2 (Switch (Iterator inputRows (DependsOn (String 'A))) '1 '('0) tr1 '('1) tr2))
  37. (return (Collect input2))
  38. ))@@;