GenericConvertTo.sql 1.6 KB

12345678910111213141516171819
  1. SELECT
  2. Yson::ConvertTo(Yson::Parse(Yson("%true")), Bool) AS `bool`,
  3. Yson::ConvertTo(Yson::Parse(Yson("123")), Int64) AS `int`,
  4. Yson::ConvertTo(Yson::Parse(Yson("123u")), Uint8) AS `uint`,
  5. Yson::ConvertTo(Yson::Parse(Yson("1.23")), Double?) AS optional_double,
  6. Yson::ConvertTo(Yson::Parse(Yson("#")), Int32?) AS empty_int,
  7. Yson::ConvertTo(Yson::Parse(Yson("\"123\"")), String) AS `string`,
  8. Yson::ConvertTo(Yson::Parse(Yson("\"приём\"")), Utf8) AS `utf8`,
  9. Yson::ConvertTo(Yson::Parse(Yson("{a=b;c=#}")), Yson?) AS `yson`,
  10. Yson::ConvertTo(Yson::Parse(Yson("[{a=1};{a=2};{a=3}]")), Json?) AS `json`,
  11. Yson::ConvertTo(Yson::Parse(Yson("[1;2;3]")), List<Int64>) AS int_list,
  12. Yson::ConvertTo(Yson::Parse(Yson("[[1;2];[3;#]]")), List<List<Int64?>>) AS nested_list,
  13. Yson::ConvertTo(Yson::Parse(Yson("{foo=1;bar=2}")), Dict<String,Int64>) AS int_dict,
  14. Yson::ConvertTo(Yson::Parse(Yson("[%false;1;\"foo\";[1;2]]")), Tuple<Bool,Int8,String?,List<Int64>>) AS `tuple`,
  15. Yson::ConvertTo(Yson::Parse(Yson("{a=%false;b=1;c=foo;d=[1;2];e=[1.0;bar]}")), Struct<a:Bool,b:Int8,c:String?,d:List<Int64>,e:Tuple<Double,String>>) AS `struct`,
  16. Yson::Serialize(Yson::ConvertTo(Yson::Parse(Yson("foo")), Resource<'Yson2.Node'>)) AS `resource`,
  17. Yson::ConvertTo(Yson::Parse(Yson("[-3.1416; 42.0; 0.003]")), List<Float>) AS list_of_floats,
  18. Yson::ConvertTo(@@{a=[1]}@@y, Struct<a: Struct<b: Int64>>?, Yson::Options(false AS Strict)) as bad_member,
  19. Yson::ConvertTo(@@[1;2]@@y, Tuple<Int64, Tuple<Int64>>?, Yson::Options(false AS Strict)) as bad_element;