diff --git a/coral-common/src/main/java/com/linkedin/coral/common/transformers/JsonTransformSqlCallTransformer.java b/coral-common/src/main/java/com/linkedin/coral/common/transformers/JsonTransformSqlCallTransformer.java index 98d5c9710..2b5b6ad85 100644 --- a/coral-common/src/main/java/com/linkedin/coral/common/transformers/JsonTransformSqlCallTransformer.java +++ b/coral-common/src/main/java/com/linkedin/coral/common/transformers/JsonTransformSqlCallTransformer.java @@ -52,13 +52,13 @@ public class JsonTransformSqlCallTransformer extends SourceOperatorMatchSqlCallT OP_MAP.put("%", SqlStdOperatorTable.MOD); OP_MAP.put("date", new SqlUserDefinedFunction(new SqlIdentifier("date", SqlParserPos.ZERO), ReturnTypes.DATE, null, OperandTypes.STRING, null, null)); - OP_MAP.put("timestamp", new SqlUserDefinedFunction(new SqlIdentifier("timestamp", SqlParserPos.ZERO), + OP_MAP.put("trino_timestamp", new SqlUserDefinedFunction(new SqlIdentifier("trino_timestamp", SqlParserPos.ZERO), FunctionReturnTypes.TIMESTAMP, null, OperandTypes.STRING, null, null) { @Override public void unparse(SqlWriter writer, SqlCall call, int leftPrec, int rightPrec) { - // for timestamp operator, we need to construct `CAST(x AS TIMESTAMP)` + // for timestamp operator, we need to construct `TRY_CAST(x AS TIMESTAMP)` Preconditions.checkState(call.operandCount() == 1); - final SqlWriter.Frame frame = writer.startFunCall("CAST"); + final SqlWriter.Frame frame = writer.startFunCall("TRY_CAST"); call.operand(0).unparse(writer, 0, 0); writer.sep("AS"); writer.literal("TIMESTAMP"); diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/CoralToTrinoSqlCallConverter.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/CoralToTrinoSqlCallConverter.java index ca2cde7f6..3c932ca4c 100644 --- a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/CoralToTrinoSqlCallConverter.java +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/CoralToTrinoSqlCallConverter.java @@ -94,15 +94,15 @@ protected SqlCall transform(SqlCall sqlCall) { "[{\"regex\":\"(?i)('utf-8')\", \"input\":2, \"name\":\"from_utf8\"}]", "[{\"input\":1}]", null, null), new JsonTransformSqlCallTransformer(hiveToCoralSqlOperator("date_add"), 2, "date_add", "[{\"value\": 'day'}, {\"input\": 2}, " - + "{\"op\": \"date\", \"operands\":[{\"op\": \"timestamp\", \"operands\":[{\"input\": 1}]}]}]", + + "{\"op\": \"date\", \"operands\":[{\"op\": \"trino_timestamp\", \"operands\":[{\"input\": 1}]}]}]", null, null), new JsonTransformSqlCallTransformer(hiveToCoralSqlOperator("date_sub"), 2, "date_add", "[{\"value\": 'day'}, " + "{\"op\": \"*\", \"operands\":[{\"input\": 2}, {\"value\": -1}]}, " - + "{\"op\": \"date\", \"operands\":[{\"op\": \"timestamp\", \"operands\":[{\"input\": 1}]}]}]", + + "{\"op\": \"date\", \"operands\":[{\"op\": \"trino_timestamp\", \"operands\":[{\"input\": 1}]}]}]", null, null), new JsonTransformSqlCallTransformer(hiveToCoralSqlOperator("datediff"), 2, "date_diff", - "[{\"value\": 'day'}, {\"op\": \"date\", \"operands\":[{\"op\": \"timestamp\", \"operands\":[{\"input\": 2}]}]}, " - + "{\"op\": \"date\", \"operands\":[{\"op\": \"timestamp\", \"operands\":[{\"input\": 1}]}]}]", + "[{\"value\": 'day'}, {\"op\": \"date\", \"operands\":[{\"op\": \"trino_timestamp\", \"operands\":[{\"input\": 2}]}]}, " + + "{\"op\": \"date\", \"operands\":[{\"op\": \"trino_timestamp\", \"operands\":[{\"input\": 1}]}]}]", null, null), new ToDateOperatorTransformer(configs.getOrDefault(AVOID_TRANSFORM_TO_DATE_UDF, false)), new CurrentTimestampTransformer(), new FromUnixtimeOperatorTransformer(), diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/TrinoSqlDialect.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/TrinoSqlDialect.java index 58c66110f..4a393b668 100644 --- a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/TrinoSqlDialect.java +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/TrinoSqlDialect.java @@ -1,5 +1,5 @@ /** - * Copyright 2017-2023 LinkedIn Corporation. All rights reserved. + * Copyright 2017-2024 LinkedIn Corporation. All rights reserved. * Licensed under the BSD-2 Clause license. * See LICENSE in the project root for license information. */ @@ -14,6 +14,7 @@ import org.apache.calcite.sql.parser.SqlParserPos; import static com.linkedin.coral.hive.hive2rel.functions.TimestampFromUnixtime.TIMESTAMP_FROM_UNIXTIME; +import static com.linkedin.coral.trino.rel2trino.functions.TrinoTryCastFunction.TRY_CAST; public class TrinoSqlDialect extends SqlDialect { @@ -76,8 +77,11 @@ public void unparseCall(SqlWriter writer, SqlCall call, int leftPrec, int rightP unparseMapValueConstructor(writer, call, leftPrec, rightPrec); break; default: - if (call.getOperator().getName().equals("timestamp_from_unixtime")) { + String operateName = call.getOperator().getName(); + if (operateName.equals("timestamp_from_unixtime")) { TIMESTAMP_FROM_UNIXTIME.unparse(writer, call, leftPrec, rightPrec); + } else if (operateName.equalsIgnoreCase("cast")) { + TRY_CAST.unparse(writer, call, leftPrec, rightPrec); } else { super.unparseCall(writer, call, leftPrec, rightPrec); } diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoStructCastRowFunction.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoStructCastRowFunction.java index 785f65349..9c28e8c8a 100644 --- a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoStructCastRowFunction.java +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoStructCastRowFunction.java @@ -1,5 +1,5 @@ /** - * Copyright 2019-2023 LinkedIn Corporation. All rights reserved. + * Copyright 2019-2024 LinkedIn Corporation. All rights reserved. * Licensed under the BSD-2 Clause license. * See LICENSE in the project root for license information. */ @@ -21,6 +21,6 @@ */ public class TrinoStructCastRowFunction extends GenericTemplateFunction { public TrinoStructCastRowFunction(RelDataType structDataType) { - super(structDataType, "cast"); + super(structDataType, "try_cast"); } } diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoTryCastFunction.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoTryCastFunction.java new file mode 100644 index 000000000..bc0e579e4 --- /dev/null +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/functions/TrinoTryCastFunction.java @@ -0,0 +1,38 @@ +/** + * Copyright 2019-2024 LinkedIn Corporation. All rights reserved. + * Licensed under the BSD-2 Clause license. + * See LICENSE in the project root for license information. + */ +package com.linkedin.coral.trino.rel2trino.functions; + +import org.apache.calcite.sql.SqlCall; +import org.apache.calcite.sql.SqlFunction; +import org.apache.calcite.sql.SqlFunctionCategory; +import org.apache.calcite.sql.SqlIntervalQualifier; +import org.apache.calcite.sql.SqlKind; +import org.apache.calcite.sql.SqlWriter; +import org.apache.calcite.sql.fun.SqlStdOperatorTable; + + +public class TrinoTryCastFunction extends SqlFunction { + public static final TrinoTryCastFunction TRY_CAST = new TrinoTryCastFunction(); + + public TrinoTryCastFunction() { + super("try_cast", SqlKind.CAST, SqlStdOperatorTable.CAST::inferReturnType, null, null, + SqlFunctionCategory.USER_DEFINED_FUNCTION); + } + + public void unparse(SqlWriter writer, SqlCall call, int leftPrec, int rightPrec) { + assert call.operandCount() == 2; + + SqlWriter.Frame frame = writer.startFunCall(this.getName()); + call.operand(0).unparse(writer, 0, 0); + writer.sep("AS"); + if (call.operand(1) instanceof SqlIntervalQualifier) { + writer.sep("INTERVAL"); + } + + call.operand(1).unparse(writer, 0, 0); + writer.endFunCall(frame); + } +} diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/GenericProjectTransformer.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/GenericProjectTransformer.java index dfe08971e..fb6275afd 100644 --- a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/GenericProjectTransformer.java +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/GenericProjectTransformer.java @@ -1,5 +1,5 @@ /** - * Copyright 2023 LinkedIn Corporation. All rights reserved. + * Copyright 2023-2024 LinkedIn Corporation. All rights reserved. * Licensed under the BSD-2 Clause license. * See LICENSE in the project root for license information. */ @@ -303,7 +303,7 @@ private String arrayDataTypeArgumentString(ArraySqlType fromDataType, ArraySqlTy */ private String structDataTypeString(RelRecordType fromDataType, RelRecordType toDataType, String fieldNameReference) { String structDataTypeArgumentString = structDataTypeArgumentString(fromDataType, toDataType, fieldNameReference); - return (String.format("cast(%s)", structDataTypeArgumentString)); + return (String.format("TRY_CAST(%s)", structDataTypeArgumentString)); } /** diff --git a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/ToDateOperatorTransformer.java b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/ToDateOperatorTransformer.java index bccbc846c..8138d0643 100644 --- a/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/ToDateOperatorTransformer.java +++ b/coral-trino/src/main/java/com/linkedin/coral/trino/rel2trino/transformers/ToDateOperatorTransformer.java @@ -1,5 +1,5 @@ /** - * Copyright 2023 LinkedIn Corporation. All rights reserved. + * Copyright 2023-2024 LinkedIn Corporation. All rights reserved. * Licensed under the BSD-2 Clause license. * See LICENSE in the project root for license information. */ @@ -37,13 +37,13 @@ public class ToDateOperatorTransformer extends SqlCallTransformer { private static final String TO_OPERATOR_NAME = "date"; private static final int NUM_OPERANDS = 1; private static final SqlOperator TIMESTAMP_OPERATOR = - new SqlUserDefinedFunction(new SqlIdentifier("timestamp", SqlParserPos.ZERO), FunctionReturnTypes.TIMESTAMP, null, - OperandTypes.STRING, null, null) { + new SqlUserDefinedFunction(new SqlIdentifier("trino_timestamp", SqlParserPos.ZERO), FunctionReturnTypes.TIMESTAMP, + null, OperandTypes.STRING, null, null) { @Override public void unparse(SqlWriter writer, SqlCall call, int leftPrec, int rightPrec) { - // for timestamp operator, we need to construct `CAST(x AS TIMESTAMP)` + // for timestamp operator, we need to construct `TRY_CAST(x AS TIMESTAMP)` Preconditions.checkState(call.operandCount() == 1); - final SqlWriter.Frame frame = writer.startFunCall("CAST"); + final SqlWriter.Frame frame = writer.startFunCall("TRY_CAST"); call.operand(0).unparse(writer, 0, 0); writer.sep("AS"); writer.literal("TIMESTAMP"); diff --git a/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/HiveToTrinoConverterTest.java b/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/HiveToTrinoConverterTest.java index 6bec9b880..ae62b3c50 100644 --- a/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/HiveToTrinoConverterTest.java +++ b/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/HiveToTrinoConverterTest.java @@ -75,45 +75,45 @@ public Object[][] viewTestCasesProvider() { { "test", "fuzzy_union_view_single_branch_evolved", "SELECT *\n" + "FROM \"test\".\"tableb\" AS \"tableb\"\n" + "UNION ALL\n" - + "SELECT \"tablec\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + + "SELECT \"tablec\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tablec\" AS \"tablec\"" }, { "test", "fuzzy_union_view_double_branch_evolved_same", "SELECT *\n" + "FROM \"test\".\"tabled\" AS \"tabled\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tablee\" AS \"tablee\"" }, - { "test", "fuzzy_union_view_double_branch_evolved_different", "SELECT \"tablef\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + { "test", "fuzzy_union_view_double_branch_evolved_different", "SELECT \"tablef\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tablef\" AS \"tablef\"\n" + "UNION ALL\n" - + "SELECT \"tableg\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + + "SELECT \"tableg\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tableg\" AS \"tableg\"" }, { "test", "fuzzy_union_view_more_than_two_branches_evolved", "SELECT *\n" - + "FROM (SELECT \"tablef\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + + "FROM (SELECT \"tablef\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tablef\" AS \"tablef\"\n" + "UNION ALL\n" - + "SELECT \"tableg\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + + "SELECT \"tableg\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tableg\" AS \"tableg\") AS \"t1\"\n" + "UNION ALL\n" - + "SELECT \"tablef0\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + + "SELECT \"tablef0\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\") as row(\"b1\" varchar)) AS \"b\"\n" + "FROM \"test\".\"tablef\" AS \"tablef0\"" }, - { "test", "fuzzy_union_view_map_with_struct_value_evolved", "SELECT \"tableh\".\"a\" AS \"a\", TRANSFORM_VALUES(b, (k, v) -> cast(row(\"v\".\"b1\") as row(\"b1\" varchar))) AS \"b\"\n" + { "test", "fuzzy_union_view_map_with_struct_value_evolved", "SELECT \"tableh\".\"a\" AS \"a\", TRANSFORM_VALUES(b, (k, v) -> TRY_CAST(row(\"v\".\"b1\") as row(\"b1\" varchar))) AS \"b\"\n" + "FROM \"test\".\"tableh\" AS \"tableh\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tablei\" AS \"tablei\"" }, - { "test", "fuzzy_union_view_array_with_struct_value_evolved", "SELECT \"tablej\".\"a\" AS \"a\", TRANSFORM(b, x -> cast(row(\"x\".\"b1\") as row(\"b1\" varchar))) AS \"b\"\n" + { "test", "fuzzy_union_view_array_with_struct_value_evolved", "SELECT \"tablej\".\"a\" AS \"a\", TRANSFORM(b, x -> TRY_CAST(row(\"x\".\"b1\") as row(\"b1\" varchar))) AS \"b\"\n" + "FROM \"test\".\"tablej\" AS \"tablej\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tablek\" AS \"tablek\"" }, - { "test", "fuzzy_union_view_deeply_nested_struct_evolved", "SELECT \"tablel\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\", cast(row(\"b\".\"b2\".\"b3\", cast(row(\"b\".\"b2\".\"b4\".\"b5\") as row(\"b5\" varchar))) as row(\"b3\" varchar, \"b4\" row(\"b5\" varchar)))) as row(\"b1\" varchar, \"b2\" row(\"b3\" varchar, \"b4\" row(\"b5\" varchar)))) AS \"b\"\n" + { "test", "fuzzy_union_view_deeply_nested_struct_evolved", "SELECT \"tablel\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\", TRY_CAST(row(\"b\".\"b2\".\"b3\", TRY_CAST(row(\"b\".\"b2\".\"b4\".\"b5\") as row(\"b5\" varchar))) as row(\"b3\" varchar, \"b4\" row(\"b5\" varchar)))) as row(\"b1\" varchar, \"b2\" row(\"b3\" varchar, \"b4\" row(\"b5\" varchar)))) AS \"b\"\n" + "FROM \"test\".\"tablel\" AS \"tablel\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tablem\" AS \"tablem\"" }, - { "test", "fuzzy_union_view_deeply_nested_complex_struct_evolved", "SELECT \"tablen\".\"a\" AS \"a\", CAST(row(\"b\".\"b1\", transform_values(\"b\".\"m1\", (k, v) -> cast(row(\"v\".\"b1\", transform(\"v\".\"a1\", x -> cast(row(\"x\".\"b1\") as row(\"b1\" varchar)))) as row(\"b1\" varchar, \"a1\" array(row(\"b1\" varchar)))))) as row(\"b1\" varchar, \"m1\" map(varchar, row(\"b1\" varchar, \"a1\" array(row(\"b1\" varchar)))))) AS \"b\"\n" + { "test", "fuzzy_union_view_deeply_nested_complex_struct_evolved", "SELECT \"tablen\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b1\", transform_values(\"b\".\"m1\", (k, v) -> TRY_CAST(row(\"v\".\"b1\", transform(\"v\".\"a1\", x -> TRY_CAST(row(\"x\".\"b1\") as row(\"b1\" varchar)))) as row(\"b1\" varchar, \"a1\" array(row(\"b1\" varchar)))))) as row(\"b1\" varchar, \"m1\" map(varchar, row(\"b1\" varchar, \"a1\" array(row(\"b1\" varchar)))))) AS \"b\"\n" + "FROM \"test\".\"tablen\" AS \"tablen\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tableo\" AS \"tableo\"" }, { "test", "union_view_same_schema_evolution_with_different_ordering", "SELECT *\n" + "FROM \"test\".\"tablep\" AS \"tablep\"\n" + "UNION ALL\n" - + "SELECT \"tableq\".\"a\" AS \"a\", CAST(row(\"b\".\"b2\", \"b\".\"b1\", \"b\".\"b0\") as row(\"b2\" double, \"b1\" varchar, \"b0\" integer)) AS \"b\"\n" + + "SELECT \"tableq\".\"a\" AS \"a\", TRY_CAST(row(\"b\".\"b2\", \"b\".\"b1\", \"b\".\"b0\") as row(\"b2\" double, \"b1\" varchar, \"b0\" integer)) AS \"b\"\n" + "FROM \"test\".\"tableq\" AS \"tableq\"" }, { "test", "view_with_explode_string_array", "SELECT \"table_with_string_array\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\"\n" @@ -122,7 +122,7 @@ public Object[][] viewTestCasesProvider() { { "test", "view_with_outer_explode_string_array", "SELECT \"table_with_string_array\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\"\n" + "FROM \"test\".\"table_with_string_array\" AS \"table_with_string_array\"\n" - + "CROSS JOIN UNNEST(\"if\"(\"table_with_string_array\".\"b\" IS NOT NULL AND CAST(CARDINALITY(\"table_with_string_array\".\"b\") AS INTEGER) > 0, \"table_with_string_array\".\"b\", ARRAY[NULL])) AS \"t0\" (\"c\")" }, + + "CROSS JOIN UNNEST(\"if\"(\"table_with_string_array\".\"b\" IS NOT NULL AND TRY_CAST(CARDINALITY(\"table_with_string_array\".\"b\") AS INTEGER) > 0, \"table_with_string_array\".\"b\", ARRAY[NULL])) AS \"t0\" (\"c\")" }, { "test", "view_with_explode_struct_array", "SELECT \"table_with_struct_array\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\"\n" + "FROM \"test\".\"table_with_struct_array\" AS \"table_with_struct_array\"\n" @@ -130,7 +130,7 @@ public Object[][] viewTestCasesProvider() { { "test", "view_with_outer_explode_struct_array", "SELECT \"table_with_struct_array\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\"\n" + "FROM \"test\".\"table_with_struct_array\" AS \"table_with_struct_array\"\n" - + "CROSS JOIN UNNEST(TRANSFORM(\"if\"(\"table_with_struct_array\".\"b\" IS NOT NULL AND CAST(CARDINALITY(\"table_with_struct_array\".\"b\") AS INTEGER) > 0, \"table_with_struct_array\".\"b\", ARRAY[NULL]), x -> ROW(x))) AS \"t0\" (\"c\")" }, + + "CROSS JOIN UNNEST(TRANSFORM(\"if\"(\"table_with_struct_array\".\"b\" IS NOT NULL AND TRY_CAST(CARDINALITY(\"table_with_struct_array\".\"b\") AS INTEGER) > 0, \"table_with_struct_array\".\"b\", ARRAY[NULL]), x -> ROW(x))) AS \"t0\" (\"c\")" }, { "test", "view_with_explode_map", "SELECT \"table_with_map\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\", \"t0\".\"d\" AS \"d\"\n" + "FROM \"test\".\"table_with_map\" AS \"table_with_map\"\n" @@ -138,12 +138,12 @@ public Object[][] viewTestCasesProvider() { { "test", "view_with_outer_explode_map", "SELECT \"table_with_map\".\"a\" AS \"a\", \"t0\".\"c\" AS \"c\", \"t0\".\"d\" AS \"d\"\n" + "FROM \"test\".\"table_with_map\" AS \"table_with_map\"\n" - + "CROSS JOIN UNNEST(\"if\"(\"table_with_map\".\"b\" IS NOT NULL AND CAST(CARDINALITY(\"table_with_map\".\"b\") AS INTEGER) > 0, \"table_with_map\".\"b\", MAP (ARRAY[NULL], ARRAY[NULL]))) AS \"t0\" (\"c\", \"d\")" }, + + "CROSS JOIN UNNEST(\"if\"(\"table_with_map\".\"b\" IS NOT NULL AND TRY_CAST(CARDINALITY(\"table_with_map\".\"b\") AS INTEGER) > 0, \"table_with_map\".\"b\", MAP (ARRAY[NULL], ARRAY[NULL]))) AS \"t0\" (\"c\", \"d\")" }, { "test", "map_array_view", "SELECT MAP (ARRAY['key1', 'key2'], ARRAY['value1', 'value2']) AS \"simple_map_col\", MAP (ARRAY['key1', 'key2'], ARRAY[MAP (ARRAY['a', 'c'], ARRAY['b', 'd']), MAP (ARRAY['a', 'c'], ARRAY['b', 'd'])]) AS \"nested_map_col\"\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, - { "test", "current_date_and_timestamp_view", "SELECT CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3)), TRIM(CAST(CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3)) AS VARCHAR(65535))) AS \"ct\", CURRENT_DATE, CURRENT_DATE AS \"cd\", \"tablea\".\"a\" AS \"a\"\n" + { "test", "current_date_and_timestamp_view", "SELECT TRY_CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3)), TRIM(TRY_CAST(TRY_CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3)) AS VARCHAR(65535))) AS \"ct\", CURRENT_DATE, CURRENT_DATE AS \"cd\", \"tablea\".\"a\" AS \"a\"\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, { "test", "date_function_view", "SELECT \"date\"('2021-01-02') AS \"a\"\n" @@ -151,25 +151,25 @@ public Object[][] viewTestCasesProvider() { { "test", "lateral_view_json_tuple_view", "SELECT \"tablea\".\"a\" AS \"a\", \"t0\".\"d\" AS \"d\", \"t0\".\"e\" AS \"e\", \"t0\".\"f\" AS \"f\"\n" + "FROM \"test\".\"tablea\" AS \"tablea\"\nCROSS JOIN LATERAL (SELECT " - + "\"if\"(\"REGEXP_LIKE\"('trino', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'trino' || '\"]') AS VARCHAR(65535)), NULL) AS \"d\", " - + "\"if\"(\"REGEXP_LIKE\"('always', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'always' || '\"]') AS VARCHAR(65535)), NULL) AS \"e\", " - + "\"if\"(\"REGEXP_LIKE\"('rocks', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'rocks' || '\"]') AS VARCHAR(65535)), NULL) AS \"f\"\n" + + "\"if\"(\"REGEXP_LIKE\"('trino', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'trino' || '\"]') AS VARCHAR(65535)), NULL) AS \"d\", " + + "\"if\"(\"REGEXP_LIKE\"('always', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'always' || '\"]') AS VARCHAR(65535)), NULL) AS \"e\", " + + "\"if\"(\"REGEXP_LIKE\"('rocks', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'rocks' || '\"]') AS VARCHAR(65535)), NULL) AS \"f\"\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")) AS \"t0\" (\"d\", \"e\", \"f\")" }, { "test", "lateral_view_json_tuple_view_qualified", "SELECT \"tablea\".\"a\" AS \"a\", \"t0\".\"d\" AS \"d\", \"t0\".\"e\" AS \"e\", \"t0\".\"f\" AS \"f\"\n" + "FROM \"test\".\"tablea\" AS \"tablea\"\nCROSS JOIN LATERAL (SELECT " - + "\"if\"(\"REGEXP_LIKE\"('trino', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'trino' || '\"]') AS VARCHAR(65535)), NULL) AS \"d\", " - + "\"if\"(\"REGEXP_LIKE\"('always', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'always' || '\"]') AS VARCHAR(65535)), NULL) AS \"e\", " - + "\"if\"(\"REGEXP_LIKE\"('rocks', '^[^\\\"]*$'), CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'rocks' || '\"]') AS VARCHAR(65535)), NULL) AS \"f\"\n" + + "\"if\"(\"REGEXP_LIKE\"('trino', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'trino' || '\"]') AS VARCHAR(65535)), NULL) AS \"d\", " + + "\"if\"(\"REGEXP_LIKE\"('always', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'always' || '\"]') AS VARCHAR(65535)), NULL) AS \"e\", " + + "\"if\"(\"REGEXP_LIKE\"('rocks', '^[^\\\"]*$'), TRY_CAST(\"json_extract\"(\"tablea\".\"b\".\"b1\", '$[\"' || 'rocks' || '\"]') AS VARCHAR(65535)), NULL) AS \"f\"\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")) AS \"t0\" (\"d\", \"e\", \"f\")" }, { "test", "get_json_object_view", "SELECT \"json_extract\"(\"tablea\".\"b\".\"b1\", '$.name')\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, - { "test", "view_from_utc_timestamp", "SELECT CAST(\"at_timezone\"(\"from_unixtime_nanos\"(CAST(\"table_from_utc_timestamp\".\"a_tinyint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime_nanos\"(CAST(\"table_from_utc_timestamp\".\"a_smallint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime_nanos\"(CAST(\"table_from_utc_timestamp\".\"a_integer\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime_nanos\"(CAST(\"table_from_utc_timestamp\".\"a_bigint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(CAST(\"table_from_utc_timestamp\".\"a_float\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(CAST(\"table_from_utc_timestamp\".\"a_double\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(CAST(\"table_from_utc_timestamp\".\"a_decimal_three\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(CAST(\"table_from_utc_timestamp\".\"a_decimal_zero\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp\".\"a_timestamp\", 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(CAST(\"table_from_utc_timestamp\".\"a_date\" AS TIMESTAMP), 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3))\n" + { "test", "view_from_utc_timestamp", "SELECT TRY_CAST(\"at_timezone\"(\"from_unixtime_nanos\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_tinyint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime_nanos\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_smallint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime_nanos\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_integer\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime_nanos\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_bigint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_float\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_double\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_decimal_three\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_decimal_zero\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp\".\"a_timestamp\", 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), TRY_CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_date\" AS TIMESTAMP), 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3))\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp\"" }, - { "test", "date_calculation_view", "SELECT \"date\"(CAST(\"substr\"('2021-08-20', 1, 10) AS TIMESTAMP)), \"date\"(CAST('2021-08-20' AS TIMESTAMP)), \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP)), \"date_add\"('day', 1, \"date\"(CAST('2021-08-20' AS TIMESTAMP))), \"date_add\"('day', 1, \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))), \"date_add\"('day', 1 * -1, \"date\"(CAST('2021-08-20' AS TIMESTAMP))), \"date_add\"('day', 1 * -1, \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))), CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-21' AS TIMESTAMP)), \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-19' AS TIMESTAMP)), \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-19 23:59:59' AS TIMESTAMP)), \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS INTEGER)\n" + { "test", "date_calculation_view", "SELECT \"date\"(TRY_CAST(\"substr\"('2021-08-20', 1, 10) AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP)), \"date_add\"('day', 1, \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))), \"date_add\"('day', 1, \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))), \"date_add\"('day', 1 * -1, \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))), \"date_add\"('day', 1 * -1, \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))), TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-21' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-19' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-19 23:59:59' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS INTEGER)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, { "test", "pmod_view", "SELECT MOD(MOD(- 9, 4) + 4, 4)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, @@ -177,13 +177,13 @@ public Object[][] viewTestCasesProvider() { { "test", "nullscollationd_view", "SELECT *\n" + "FROM \"test\".\"tabler\" AS \"tabler\"\n" + "ORDER BY \"tabler\".\"b\" DESC" }, - { "test", "view_with_date_and_interval", "SELECT (CAST('2021-08-30' AS DATE) + INTERVAL '3' DAY)\n" + { "test", "view_with_date_and_interval", "SELECT (TRY_CAST('2021-08-30' AS DATE) + INTERVAL '3' DAY)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, - { "test", "view_with_timestamp_and_interval", "SELECT (CAST('2021-08-30' AS TIMESTAMP) + INTERVAL -'3 01:02:03' DAY TO SECOND)\n" + { "test", "view_with_timestamp_and_interval", "SELECT (TRY_CAST('2021-08-30' AS TIMESTAMP) + INTERVAL -'3 01:02:03' DAY TO SECOND)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, - { "test", "view_with_timestamp_and_interval_2", "SELECT (CAST('2021-08-30' AS TIMESTAMP) + INTERVAL -'1-6' YEAR TO MONTH)\n" + { "test", "view_with_timestamp_and_interval_2", "SELECT (TRY_CAST('2021-08-30' AS TIMESTAMP) + INTERVAL -'1-6' YEAR TO MONTH)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"" }, { "test", "greatest_view", "SELECT \"greatest\"(\"table_ints_strings\".\"a\", \"table_ints_strings\".\"b\") AS \"g_int\", \"greatest\"(\"table_ints_strings\".\"c\", \"table_ints_strings\".\"d\") AS \"g_string\"\n" @@ -192,37 +192,37 @@ public Object[][] viewTestCasesProvider() { { "test", "least_view", "SELECT \"least\"(\"table_ints_strings\".\"a\", \"table_ints_strings\".\"b\") AS \"g_int\", \"least\"(\"table_ints_strings\".\"c\", \"table_ints_strings\".\"d\") AS \"g_string\"\n" + "FROM \"test\".\"table_ints_strings\" AS \"table_ints_strings\"" }, - { "test", "cast_decimal_view", "SELECT CAST(\"table_ints_strings\".\"a\" AS DECIMAL(6, 2)) AS \"casted_decimal\"\n" + { "test", "cast_decimal_view", "SELECT TRY_CAST(\"table_ints_strings\".\"a\" AS DECIMAL(6, 2)) AS \"casted_decimal\"\n" + "FROM \"test\".\"table_ints_strings\" AS \"table_ints_strings\"" }, { "test", "view_namesake_column_names", "SELECT \"t0\".\"some_id\" AS \"some_id\"\n" + "FROM (SELECT \"duplicate_column_name_a\".\"some_id\" AS \"some_id\", \"t\".\"SOME_ID\" AS \"SOME_ID0\"\n" + "FROM \"test\".\"duplicate_column_name_a\" AS \"duplicate_column_name_a\"\n" - + "LEFT JOIN (SELECT TRIM(\"duplicate_column_name_b\".\"some_id\") AS \"SOME_ID\", CAST(TRIM(\"duplicate_column_name_b\".\"some_id\") AS VARCHAR(65536)) AS \"$f1\"\n" + + "LEFT JOIN (SELECT TRIM(\"duplicate_column_name_b\".\"some_id\") AS \"SOME_ID\", TRY_CAST(TRIM(\"duplicate_column_name_b\".\"some_id\") AS VARCHAR(65536)) AS \"$f1\"\n" + "FROM \"test\".\"duplicate_column_name_b\" AS \"duplicate_column_name_b\") AS \"t\" ON \"duplicate_column_name_a\".\"some_id\" = \"t\".\"$f1\") AS \"t0\"\n" + "WHERE \"t0\".\"some_id\" <> ''" }, - { "test", "view_char_different_size_in_union", "SELECT CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(255)) AS \"col\"\n" + { "test", "view_char_different_size_in_union", "SELECT TRY_CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(255)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns\"\n" + "UNION ALL\n" - + "SELECT CAST(\"table_with_mixed_columns0\".\"a_char255\" AS VARCHAR(255)) AS \"col\"\n" + + "SELECT TRY_CAST(\"table_with_mixed_columns0\".\"a_char255\" AS VARCHAR(255)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns0\"" }, - { "test", "view_cast_char_to_varchar", "SELECT CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + { "test", "view_cast_char_to_varchar", "SELECT TRY_CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns\"" }, - { "test", "view_cast_char_to_varchar_in_union", "SELECT CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + { "test", "view_cast_char_to_varchar_in_union", "SELECT TRY_CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns\"\n" + "UNION ALL\n" - + "SELECT CAST(CASE WHEN \"table_with_mixed_columns0\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns0\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"col\"\n" + + "SELECT TRY_CAST(CASE WHEN \"table_with_mixed_columns0\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns0\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns0\"" }, - { "test", "view_cast_char_to_varchar_in_union_flipped", "SELECT CAST(CASE WHEN \"table_with_mixed_columns\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"col\"\n" + { "test", "view_cast_char_to_varchar_in_union_flipped", "SELECT TRY_CAST(CASE WHEN \"table_with_mixed_columns\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns\"\n" + "UNION ALL\n" - + "SELECT CAST(\"table_with_mixed_columns0\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + + "SELECT TRY_CAST(\"table_with_mixed_columns0\".\"a_char1\" AS VARCHAR(65535)) AS \"col\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns0\"" }, - { "test", "view_cast_char_to_varchar_with_other_fields_in_union", "SELECT CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"text\", \"table_with_mixed_columns\".\"a_boolean\" AS \"a_boolean\", \"table_with_mixed_columns\".\"a_smallint\" AS \"a_number\"\n" + { "test", "view_cast_char_to_varchar_with_other_fields_in_union", "SELECT TRY_CAST(\"table_with_mixed_columns\".\"a_char1\" AS VARCHAR(65535)) AS \"text\", \"table_with_mixed_columns\".\"a_boolean\" AS \"a_boolean\", \"table_with_mixed_columns\".\"a_smallint\" AS \"a_number\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns\"\n" + "UNION ALL\n" - + "SELECT CAST(CASE WHEN \"table_with_mixed_columns0\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns0\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"text\", \"table_with_mixed_columns0\".\"a_boolean\" AS \"a_boolean\", \"table_with_mixed_columns0\".\"a_integer\" AS \"a_number\"\n" + + "SELECT TRY_CAST(CASE WHEN \"table_with_mixed_columns0\".\"a_char1\" IS NOT NULL THEN \"table_with_mixed_columns0\".\"a_char1\" ELSE 'N' END AS VARCHAR(65535)) AS \"text\", \"table_with_mixed_columns0\".\"a_boolean\" AS \"a_boolean\", \"table_with_mixed_columns0\".\"a_integer\" AS \"a_number\"\n" + "FROM \"test\".\"table_with_mixed_columns\" AS \"table_with_mixed_columns0\"" }, { "test", "view_char_and_null_in_union", "SELECT \"table_with_mixed_columns\".\"a_char1\" AS \"text\"\n" @@ -357,7 +357,7 @@ public void testLateralViewOuterPosExplodeWithAlias() { "SELECT col FROM (SELECT ARRAY('a1', 'a2') as a) tmp LATERAL VIEW OUTER POSEXPLODE(a) a_alias AS pos, col"); String targetSql = "SELECT \"t2\".\"col\" AS \"col\"\n" + "FROM (SELECT ARRAY['a1', 'a2'] AS \"a\"\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")) AS \"t0\"\n" - + "CROSS JOIN UNNEST(\"if\"(\"t0\".\"a\" IS NOT NULL AND CAST(CARDINALITY(\"t0\".\"a\") AS INTEGER) > 0, \"t0\".\"a\", ARRAY[NULL])) WITH ORDINALITY AS \"t2\" (\"col\", \"pos\")"; + + "CROSS JOIN UNNEST(\"if\"(\"t0\".\"a\" IS NOT NULL AND TRY_CAST(CARDINALITY(\"t0\".\"a\") AS INTEGER) > 0, \"t0\".\"a\", ARRAY[NULL])) WITH ORDINALITY AS \"t2\" (\"col\", \"pos\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); String expandedSql = relToTrinoConverter.convert(relNode); @@ -380,8 +380,8 @@ public void testAvoidTransformToDate() { @Test public void testIfWithNullAsSecondParameter() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT if(FALSE, NULL, named_struct('a', ''))"); - String targetSql = - "SELECT \"if\"(FALSE, NULL, CAST(ROW('') AS ROW(\"a\" CHAR(0))))\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = "SELECT \"if\"(FALSE, NULL, TRY_CAST(ROW('') AS ROW(\"a\" CHAR(0))))\n" + + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); String expandedSql = relToTrinoConverter.convert(relNode); @@ -391,7 +391,7 @@ public void testIfWithNullAsSecondParameter() { @Test public void testNamedStructWithArrayWithoutType() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT NAMED_STRUCT('value', ARRAY())"); - String targetSql = "SELECT CAST(ROW(ARRAY[]) AS ROW(\"value\" ARRAY))\n" + String targetSql = "SELECT TRY_CAST(ROW(ARRAY[]) AS ROW(\"value\" ARRAY))\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); @@ -404,7 +404,7 @@ public void testNestedNamedStructWithArrayWithoutType() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT NAMED_STRUCT('value', NAMED_STRUCT('value2', ARRAY()))"); String targetSql = - "SELECT CAST(ROW(CAST(ROW(ARRAY[]) AS ROW(\"value2\" ARRAY))) AS ROW(\"value\" ROW(\"value2\" ARRAY)))\n" + "SELECT TRY_CAST(ROW(TRY_CAST(ROW(ARRAY[]) AS ROW(\"value2\" ARRAY))) AS ROW(\"value\" ROW(\"value2\" ARRAY)))\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); @@ -417,7 +417,7 @@ public void testNamedStructWithStringTypeArray() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT NAMED_STRUCT('value', ARRAY(CAST('tmp' AS STRING)))"); String targetSql = - "SELECT CAST(ROW(ARRAY[CAST('tmp' AS VARCHAR(65535))]) AS ROW(\"value\" ARRAY))\n" + "SELECT TRY_CAST(ROW(ARRAY[TRY_CAST('tmp' AS VARCHAR(65535))]) AS ROW(\"value\" ARRAY))\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); @@ -429,9 +429,9 @@ public void testNamedStructWithStringTypeArray() { public void testNamedStructWithConcat() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT if(FALSE, NULL, named_struct('a', '')) from test.tableB where concat(current_date(), '|', tableB.a) = 'invalid'"); - String targetSql = "SELECT \"if\"(FALSE, NULL, CAST(ROW('') AS ROW(\"a\" CHAR(0))))\n" + String targetSql = "SELECT \"if\"(FALSE, NULL, TRY_CAST(ROW('') AS ROW(\"a\" CHAR(0))))\n" + "FROM \"test\".\"tableb\" AS \"tableb\"\n" - + "WHERE \"concat\"(CAST(CURRENT_DATE AS VARCHAR(65535)), '|', CAST(\"tableb\".\"a\" AS VARCHAR(65535))) = 'invalid'"; + + "WHERE \"concat\"(TRY_CAST(CURRENT_DATE AS VARCHAR(65535)), '|', TRY_CAST(\"tableb\".\"a\" AS VARCHAR(65535))) = 'invalid'"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); String expandedSql = relToTrinoConverter.convert(relNode); @@ -441,8 +441,8 @@ public void testNamedStructWithConcat() { @Test public void testIfWithNullAsThirdParameter() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT if(FALSE, named_struct('a', ''), NULL)"); - String targetSql = - "SELECT \"if\"(FALSE, CAST(ROW('') AS ROW(\"a\" CHAR(0))), NULL)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = "SELECT \"if\"(FALSE, TRY_CAST(ROW('') AS ROW(\"a\" CHAR(0))), NULL)\n" + + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); String expandedSql = relToTrinoConverter.convert(relNode); @@ -453,7 +453,7 @@ public void testIfWithNullAsThirdParameter() { public void testSelectNullFields() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT NULL, NULL AS TMP, CAST(NULL AS BINARY)"); String targetSql = - "SELECT NULL, NULL AS \"TMP\", CAST(NULL AS VARBINARY)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + "SELECT NULL, NULL AS \"TMP\", TRY_CAST(NULL AS VARBINARY)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); String expandedSql = relToTrinoConverter.convert(relNode); @@ -558,7 +558,7 @@ public void testCastTimestampToDecimal() { RelNode relNode = TestUtils.getHiveToRelConverter() .convertSql("SELECT CAST(a_timestamp AS DECIMAL(10, 0)) AS d\nFROM test.table_from_utc_timestamp"); String targetSql = - "SELECT CAST(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp\".\"a_timestamp\", 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "SELECT TRY_CAST(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp\".\"a_timestamp\", 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -571,7 +571,7 @@ public void testCastNestedTimestampToDecimal() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT CAST(CAST(a_date AS TIMESTAMP) AS DECIMAL(10, 0)) AS d\nFROM test.table_from_utc_timestamp"); String targetSql = - "SELECT CAST(\"to_unixtime\"(\"with_timezone\"(CAST(\"table_from_utc_timestamp\".\"a_date\" AS TIMESTAMP), 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "SELECT TRY_CAST(\"to_unixtime\"(\"with_timezone\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_date\" AS TIMESTAMP), 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -579,7 +579,7 @@ public void testCastNestedTimestampToDecimal() { relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT CAST(from_utc_timestamp(a_date, 'America/Los_Angeles') AS DECIMAL(10, 0)) AS d\nFROM test.table_from_utc_timestamp"); targetSql = - "SELECT CAST(\"to_unixtime\"(\"with_timezone\"(CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(CAST(\"table_from_utc_timestamp0\".\"a_date\" AS TIMESTAMP), 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "SELECT TRY_CAST(\"to_unixtime\"(\"with_timezone\"(TRY_CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(TRY_CAST(\"table_from_utc_timestamp0\".\"a_date\" AS TIMESTAMP), 'UTC'))), \"$canonicalize_hive_timezone_id\"('America/Los_Angeles')) AS TIMESTAMP(3)), 'UTC')) AS DECIMAL(10, 0)) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp0\""; expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -589,7 +589,7 @@ public void testCastNestedTimestampToDecimal() { public void testCastWithJoinOnTableAlias() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT t1.*, CAST('123' AS INT) FROM (SELECT * FROM test.tableA) t1 LEFT OUTER JOIN test.tableB t2 ON t1.a = t2.a"); - String targetSql = "SELECT \"tablea\".\"a\" AS \"a\", \"tablea\".\"b\" AS \"b\", CAST('123' AS INTEGER)\n" + String targetSql = "SELECT \"tablea\".\"a\" AS \"a\", \"tablea\".\"b\" AS \"b\", TRY_CAST('123' AS INTEGER)\n" + "FROM \"test\".\"tablea\" AS \"tablea\"\n" + "LEFT JOIN \"test\".\"tableb\" AS \"tableb\" ON \"tablea\".\"a\" = \"tableb\".\"a\""; @@ -605,7 +605,7 @@ public void testSubstrWithTimestampOperator() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT substring(from_utc_timestamp(a_bigint,'PST'),1,10) AS d\nFROM test.table_from_utc_timestamp"); String targetSql = - "SELECT \"substr\"(CAST(CAST(\"at_timezone\"(\"from_unixtime_nanos\"(CAST(\"table_from_utc_timestamp\".\"a_bigint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "SELECT \"substr\"(TRY_CAST(TRY_CAST(\"at_timezone\"(\"from_unixtime_nanos\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_bigint\" AS BIGINT) * 1000000), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -613,7 +613,7 @@ public void testSubstrWithTimestampOperator() { relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT substring(from_utc_timestamp(a_decimal_three,'PST'),1,10) AS d\nFROM test.table_from_utc_timestamp"); targetSql = - "SELECT \"substr\"(CAST(CAST(\"at_timezone\"(\"from_unixtime\"(CAST(\"table_from_utc_timestamp0\".\"a_decimal_three\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "SELECT \"substr\"(TRY_CAST(TRY_CAST(\"at_timezone\"(\"from_unixtime\"(TRY_CAST(\"table_from_utc_timestamp0\".\"a_decimal_three\" AS DOUBLE)), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp0\""; expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -621,7 +621,7 @@ public void testSubstrWithTimestampOperator() { relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT substring(from_utc_timestamp(a_timestamp,'PST'),1,10) AS d\nFROM test.table_from_utc_timestamp"); targetSql = - "SELECT \"substr\"(CAST(CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp1\".\"a_timestamp\", 'UTC'))), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "SELECT \"substr\"(TRY_CAST(TRY_CAST(\"at_timezone\"(\"from_unixtime\"(\"to_unixtime\"(\"with_timezone\"(\"table_from_utc_timestamp1\".\"a_timestamp\", 'UTC'))), \"$canonicalize_hive_timezone_id\"('PST')) AS TIMESTAMP(3)) AS VARCHAR(65535)), 1, 10) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp1\""; expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -644,7 +644,7 @@ public void testCastByTypeName() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT CAST(1 AS DOUBLE), CAST(1.5 AS INT), CAST(2.3 AS STRING), CAST(1631142817 AS TIMESTAMP), CAST('' AS BOOLEAN)"); String targetSql = - "SELECT CAST(1 AS DOUBLE), CAST(1.5 AS INTEGER), CAST(2.3 AS VARCHAR(65535)), CAST(1631142817 AS TIMESTAMP), CAST('' AS BOOLEAN)\n" + "SELECT TRY_CAST(1 AS DOUBLE), TRY_CAST(1.5 AS INTEGER), TRY_CAST(2.3 AS VARCHAR(65535)), TRY_CAST(1631142817 AS TIMESTAMP), TRY_CAST('' AS BOOLEAN)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -667,7 +667,7 @@ public void testResetTransformColumnFieldNameForGenericProject() { String targetSql = "SELECT \"t1\".\"struct_col\" AS \"structCol\"\n" + "FROM (SELECT \"tables\".\"structcol\" AS \"struct_col\"\n" + "FROM \"test\".\"tables\" AS \"tables\"\n" - + "UNION ALL\n" + "SELECT CAST(row(\"structcol\".\"a\") as row(\"a\" integer)) AS \"struct_col\"\n" + + "UNION ALL\n" + "SELECT TRY_CAST(row(\"structcol\".\"a\") as row(\"a\" integer)) AS \"struct_col\"\n" + "FROM \"test\".\"tablet\" AS \"tablet\") AS \"t1\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -680,7 +680,7 @@ public void testTypeCastForDateDiffFunction() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT datediff('2021-08-20', '2021-08-21'), datediff('2021-08-20', '2021-08-19'), datediff('2021-08-20 00:00:00', '2021-08-19 23:59:59')"); String targetSql = - "SELECT CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-21' AS TIMESTAMP)), \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-19' AS TIMESTAMP)), \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), CAST(\"date_diff\"('day', \"date\"(CAST('2021-08-19 23:59:59' AS TIMESTAMP)), \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS INTEGER)\n" + "SELECT TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-21' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-19' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS INTEGER), TRY_CAST(\"date_diff\"('day', \"date\"(TRY_CAST('2021-08-19 23:59:59' AS TIMESTAMP)), \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS INTEGER)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -694,7 +694,7 @@ public void testTypeCastForDataAddFunction() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql( "SELECT date_add('2021-08-20', 1), date_add('2021-08-20 00:00:00', 1), date_sub('2021-08-20', 1), date_sub('2021-08-20 00:00:00', 1)"); String targetSql = - "SELECT CAST(\"date_add\"('day', 1, \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS VARCHAR), CAST(\"date_add\"('day', 1, \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS VARCHAR), CAST(\"date_add\"('day', 1 * -1, \"date\"(CAST('2021-08-20' AS TIMESTAMP))) AS VARCHAR), CAST(\"date_add\"('day', 1 * -1, \"date\"(CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS VARCHAR)\n" + "SELECT TRY_CAST(\"date_add\"('day', 1, \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS VARCHAR), TRY_CAST(\"date_add\"('day', 1, \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS VARCHAR), TRY_CAST(\"date_add\"('day', 1 * -1, \"date\"(TRY_CAST('2021-08-20' AS TIMESTAMP))) AS VARCHAR), TRY_CAST(\"date_add\"('day', 1 * -1, \"date\"(TRY_CAST('2021-08-20 00:00:00' AS TIMESTAMP))) AS VARCHAR)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -705,7 +705,7 @@ public void testTypeCastForCeilFunction() { RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT ceil(1.5)"); - String targetSql = "SELECT CAST(CEIL(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = "SELECT TRY_CAST(CEIL(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); } @@ -715,7 +715,7 @@ public void testTypeCastForCeilingFunction() { RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT ceiling(1.5)"); - String targetSql = "SELECT CAST(\"ceiling\"(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = "SELECT TRY_CAST(\"ceiling\"(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); } @@ -725,7 +725,7 @@ public void testTypeCastForFloorFunction() { RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT floor(1.5)"); - String targetSql = "SELECT CAST(FLOOR(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = "SELECT TRY_CAST(FLOOR(1.5) AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); } @@ -735,7 +735,8 @@ public void testTypeCastForCardinalityFunction() { RelToTrinoConverter relToTrinoConverter = TestUtils.getRelToTrinoConverter(); RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("SELECT size(ARRAY (1, 2))"); - String targetSql = "SELECT CAST(CARDINALITY(ARRAY[1, 2]) AS INTEGER)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; + String targetSql = + "SELECT TRY_CAST(CARDINALITY(ARRAY[1, 2]) AS INTEGER)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); } @@ -757,7 +758,7 @@ public void testSubstrWithTimestamp() { RelNode relNode = TestUtils.getHiveToRelConverter() .convertSql("SELECT SUBSTR(a_timestamp, 12, 8) AS d\nFROM test.table_from_utc_timestamp"); String targetSql = - "SELECT \"substr\"(CAST(\"table_from_utc_timestamp\".\"a_timestamp\" AS VARCHAR(65535)), 12, 8) AS \"d\"\n" + "SELECT \"substr\"(TRY_CAST(\"table_from_utc_timestamp\".\"a_timestamp\" AS VARCHAR(65535)), 12, 8) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -765,7 +766,7 @@ public void testSubstrWithTimestamp() { relNode = TestUtils.getHiveToRelConverter() .convertSql("SELECT SUBSTRING(a_timestamp, 12, 8) AS d\nFROM test.table_from_utc_timestamp"); targetSql = - "SELECT \"substr\"(CAST(\"table_from_utc_timestamp0\".\"a_timestamp\" AS VARCHAR(65535)), 12, 8) AS \"d\"\n" + "SELECT \"substr\"(TRY_CAST(\"table_from_utc_timestamp0\".\"a_timestamp\" AS VARCHAR(65535)), 12, 8) AS \"d\"\n" + "FROM \"test\".\"table_from_utc_timestamp\" AS \"table_from_utc_timestamp0\""; expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -844,7 +845,7 @@ public void testCastDecimal() { RelNode relNode = TestUtils.getHiveToRelConverter() .convertSql("SELECT CAST(t.a as DECIMAL(6, 2)) as casted_decimal FROM test.table_ints_strings t"); - String targetSql = "SELECT CAST(\"table_ints_strings\".\"a\" AS DECIMAL(6, 2)) AS \"casted_decimal\"\n" + String targetSql = "SELECT TRY_CAST(\"table_ints_strings\".\"a\" AS DECIMAL(6, 2)) AS \"casted_decimal\"\n" + "FROM \"test\".\"table_ints_strings\" AS \"table_ints_strings\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -856,7 +857,7 @@ public void testCastDecimalDefault() { RelNode relNode = TestUtils.getHiveToRelConverter() .convertSql("SELECT CAST(t.a as DECIMAL) as casted_decimal FROM test.table_ints_strings t"); - String targetSql = "SELECT CAST(\"table_ints_strings\".\"a\" AS DECIMAL(10, 0)) AS \"casted_decimal\"\n" + String targetSql = "SELECT TRY_CAST(\"table_ints_strings\".\"a\" AS DECIMAL(10, 0)) AS \"casted_decimal\"\n" + "FROM \"test\".\"table_ints_strings\" AS \"table_ints_strings\""; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -890,7 +891,7 @@ public void testDateFormatFunction() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("select date_format(date_sub(current_date(),1),'yyyyMMdd')"); String targetSql = - "SELECT \"date_format\"(\"date_add\"('day', 1 * -1, \"date\"(CAST(CURRENT_DATE AS TIMESTAMP))), 'yyyyMMdd')\n" + "SELECT \"date_format\"(\"date_add\"('day', 1 * -1, \"date\"(TRY_CAST(CURRENT_DATE AS TIMESTAMP))), 'yyyyMMdd')\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); @@ -905,7 +906,7 @@ public void testConcatWithUnionAndStar() { String expected = "SELECT *\n" + "FROM \"test\".\"tablea\" AS \"tablea\"\n" + "UNION ALL\n" + "SELECT *\n" + "FROM \"test\".\"tableb\" AS \"tableb\"\n" - + "WHERE \"concat\"(CAST(CURRENT_DATE AS VARCHAR(65535)), '|', CAST(\"tableb\".\"a\" AS VARCHAR(65535))) = 'invalid'"; + + "WHERE \"concat\"(TRY_CAST(CURRENT_DATE AS VARCHAR(65535)), '|', TRY_CAST(\"tableb\".\"a\" AS VARCHAR(65535))) = 'invalid'"; assertEquals(expandedSql, expected); } @@ -916,7 +917,7 @@ public void testConcatFunction() { RelNode relNode = TestUtils.getHiveToRelConverter().convertSql("select concat(current_date(), '|', current_date(), '-00')"); String targetSql = - "SELECT \"concat\"(CAST(CURRENT_DATE AS VARCHAR(65535)), '|', CAST(CURRENT_DATE AS VARCHAR(65535)), '-00')\n" + "SELECT \"concat\"(TRY_CAST(CURRENT_DATE AS VARCHAR(65535)), '|', TRY_CAST(CURRENT_DATE AS VARCHAR(65535)), '-00')\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")"; String expandedSql = relToTrinoConverter.convert(relNode); assertEquals(expandedSql, targetSql); diff --git a/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/RelToTrinoConverterTest.java b/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/RelToTrinoConverterTest.java index eca6cda9c..a239d6019 100644 --- a/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/RelToTrinoConverterTest.java +++ b/coral-trino/src/test/java/com/linkedin/coral/trino/rel2trino/RelToTrinoConverterTest.java @@ -297,7 +297,7 @@ private void testSetQueries(String operator) { public void testCast() { String sql = "SELECT cast(dcol as int) as d, cast(icol as double) as i FROM test.tableOne"; String expectedSql = - "SELECT CAST(\"tableone\".\"dcol\" AS INTEGER) AS \"d\", CAST(\"tableone\".\"icol\" AS DOUBLE) AS \"i\"\n" + "SELECT TRY_CAST(\"tableone\".\"dcol\" AS INTEGER) AS \"d\", TRY_CAST(\"tableone\".\"icol\" AS DOUBLE) AS \"i\"\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql, expectedSql); } @@ -306,7 +306,7 @@ public void testCast() { public void testVarcharCast() { final String sql = "SELECT cast(icol as varchar(1000)) FROM test.tableOne"; testConversion(sql, - "SELECT CAST(\"tableone\".\"icol\" AS VARCHAR(65535))\n" + "FROM \"test\".\"tableone\" AS \"tableone\""); + "SELECT TRY_CAST(\"tableone\".\"icol\" AS VARCHAR(65535))\n" + "FROM \"test\".\"tableone\" AS \"tableone\""); } @Test @@ -325,19 +325,19 @@ public void testRand() { @Test public void testRandInteger() { String sql1 = "SELECT floor(rand() * (icol - 2 + 1) + 2) FROM test.tableOne"; - String expectedSql1 = "SELECT CAST(FLOOR(\"RANDOM\"() * (\"tableone\".\"icol\" - 2 + 1) + 2) AS BIGINT)\n" + String expectedSql1 = "SELECT TRY_CAST(FLOOR(\"RANDOM\"() * (\"tableone\".\"icol\" - 2 + 1) + 2) AS BIGINT)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql1, expectedSql1); String sql2 = "SELECT floor(rand() * icol) FROM test.tableOne"; - String expectedSql2 = "SELECT CAST(FLOOR(\"RANDOM\"() * \"tableone\".\"icol\") AS BIGINT)\n" + String expectedSql2 = "SELECT TRY_CAST(FLOOR(\"RANDOM\"() * \"tableone\".\"icol\") AS BIGINT)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql2, expectedSql2); { final String sql = "SELECT icol FROM test.tableOne" + " WHERE floor(rand() * icol) > 10"; final String expected = "SELECT \"tableone\".\"icol\" AS \"icol\"\n" + "FROM \"test\".\"tableone\" AS \"tableone\"\n" - + "WHERE CAST(FLOOR(\"RANDOM\"() * \"tableone\".\"icol\") AS BIGINT) > 10"; + + "WHERE TRY_CAST(FLOOR(\"RANDOM\"() * \"tableone\".\"icol\") AS BIGINT) > 10"; testConversion(sql, expected); } } @@ -346,12 +346,12 @@ public void testRandInteger() { public void testTruncate() { String sql1 = "SELECT floor(dcol) FROM test.tableOne"; String expectedSql1 = - "SELECT CAST(FLOOR(\"tableone\".\"dcol\") AS BIGINT)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; + "SELECT TRY_CAST(FLOOR(\"tableone\".\"dcol\") AS BIGINT)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql1, expectedSql1); String sql2 = "SELECT round(dcol, 2 - floor(log10(abs(dcol))) - 1) FROM test.tableOne"; String expectedSql2 = - "SELECT ROUND(\"tableone\".\"dcol\", 2 - CAST(FLOOR(LOG10(ABS(\"tableone\".\"dcol\"))) AS BIGINT) - 1)\n" + "SELECT ROUND(\"tableone\".\"dcol\", 2 - TRY_CAST(FLOOR(LOG10(ABS(\"tableone\".\"dcol\"))) AS BIGINT) - 1)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql2, expectedSql2); } @@ -487,8 +487,8 @@ public void testOuterJoin() { public void testTryCastIntTrino() { String sql = "SELECT CASE WHEN a.scol= 0 THEN TRUE ELSE FALSE END AS testcol FROM test.tableOne a WHERE a.scol = 1"; String expectedSql = - "SELECT CASE WHEN CAST(\"tableone\".\"scol\" AS INTEGER) = 0 THEN TRUE ELSE FALSE END AS \"testcol\"\n" - + "FROM \"test\".\"tableone\" AS \"tableone\"\n" + "WHERE CAST(\"tableone\".\"scol\" AS INTEGER) = 1"; + "SELECT CASE WHEN TRY_CAST(\"tableone\".\"scol\" AS INTEGER) = 0 THEN TRUE ELSE FALSE END AS \"testcol\"\n" + + "FROM \"test\".\"tableone\" AS \"tableone\"\n" + "WHERE TRY_CAST(\"tableone\".\"scol\" AS INTEGER) = 1"; testConversion(sql, expectedSql); } @@ -497,8 +497,9 @@ public void testTryCastBooleanTrino() { String sql = "SELECT CASE WHEN a.scol= TRUE THEN TRUE ELSE FALSE END AS testcol FROM test.tableOne" + " a WHERE a.scol = FALSE"; String expectedSql = - "SELECT CASE WHEN CAST(\"tableone\".\"scol\" AS BOOLEAN) = TRUE THEN TRUE ELSE FALSE END AS \"testcol\"\n" - + "FROM \"test\".\"tableone\" AS \"tableone\"\n" + "WHERE CAST(\"tableone\".\"scol\" AS BOOLEAN) = FALSE"; + "SELECT CASE WHEN TRY_CAST(\"tableone\".\"scol\" AS BOOLEAN) = TRUE THEN TRUE ELSE FALSE END AS \"testcol\"\n" + + "FROM \"test\".\"tableone\" AS \"tableone\"\n" + + "WHERE TRY_CAST(\"tableone\".\"scol\" AS BOOLEAN) = FALSE"; testConversion(sql, expectedSql); } @@ -518,16 +519,17 @@ public void testCase() { @Test public void testDataTypeSpecRewrite() { String sql1 = "SELECT CAST(icol AS FLOAT) FROM test.tableOne"; - String expectedSql1 = "SELECT CAST(\"tableone\".\"icol\" AS REAL)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; + String expectedSql1 = + "SELECT TRY_CAST(\"tableone\".\"icol\" AS REAL)\n" + "FROM \"test\".\"tableone\" AS \"tableone\""; testConversion(sql1, expectedSql1); String sql2 = "SELECT CAST(binaryfield AS BINARY) FROM test.tableThree"; - String expectedSql2 = - "SELECT CAST(\"tablethree\".\"binaryfield\" AS VARBINARY)\n" + "FROM \"test\".\"tablethree\" AS \"tablethree\""; + String expectedSql2 = "SELECT TRY_CAST(\"tablethree\".\"binaryfield\" AS VARBINARY)\n" + + "FROM \"test\".\"tablethree\" AS \"tablethree\""; testConversion(sql2, expectedSql2); String sql3 = "SELECT CAST(varbinaryfield AS BINARY) FROM test.tableThree"; - String expectedSql3 = "SELECT CAST(\"tablethree\".\"varbinaryfield\" AS VARBINARY)\n" + String expectedSql3 = "SELECT TRY_CAST(\"tablethree\".\"varbinaryfield\" AS VARBINARY)\n" + "FROM \"test\".\"tablethree\" AS \"tablethree\""; testConversion(sql3, expectedSql3); } @@ -543,7 +545,7 @@ public void testCurrentUser() { public void testCurrentTimestamp() { String sql = "SELECT current_timestamp"; String expected = - formatSql("SELECT CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3))\nFROM (VALUES (0)) AS \"t\" (\"ZERO\")"); + formatSql("SELECT TRY_CAST(CURRENT_TIMESTAMP AS TIMESTAMP(3))\nFROM (VALUES (0)) AS \"t\" (\"ZERO\")"); testConversion(sql, expected); } diff --git a/coral-trino/src/test/java/com/linkedin/coral/trino/trino2rel/TrinoToRelConverterTest.java b/coral-trino/src/test/java/com/linkedin/coral/trino/trino2rel/TrinoToRelConverterTest.java index da8ca31fb..8a6a46006 100644 --- a/coral-trino/src/test/java/com/linkedin/coral/trino/trino2rel/TrinoToRelConverterTest.java +++ b/coral-trino/src/test/java/com/linkedin/coral/trino/trino2rel/TrinoToRelConverterTest.java @@ -1,5 +1,5 @@ /** - * Copyright 2021-2023 LinkedIn Corporation. All rights reserved. + * Copyright 2021-2024 LinkedIn Corporation. All rights reserved. * Licensed under the BSD-2 Clause license. * See LICENSE in the project root for license information. */ @@ -106,7 +106,7 @@ public Iterator getSupportedSql() { + "FROM \"default\".\"foo\" AS \"foo\"")) .add(new TrinoToRelTestDataProvider("select 1 + 13 || '15' from foo", "LogicalProject(EXPR$0=[concat(+(1, 13), '15')])\n" + " LogicalTableScan(table=[[hive, default, foo]])\n", - "SELECT \"concat\"(CAST(1 + 13 AS VARCHAR(65535)), '15')\n" + "FROM \"default\".\"foo\" AS \"foo\"")) + "SELECT \"concat\"(TRY_CAST(1 + 13 AS VARCHAR(65535)), '15')\n" + "FROM \"default\".\"foo\" AS \"foo\"")) .add(new TrinoToRelTestDataProvider("select x is distinct from y from foo where a is not distinct from b", "LogicalProject(EXPR$0=[AND(OR(IS NOT NULL($3), IS NOT NULL($4)), IS NOT TRUE(=($3, $4)))])\n" + " LogicalFilter(condition=[NOT(AND(OR(IS NOT NULL($1), IS NOT NULL($2)), IS NOT TRUE(=($1, $2))))])\n" @@ -125,7 +125,7 @@ public Iterator getSupportedSql() { .add(new TrinoToRelTestDataProvider("select x[cast(10 * sin(z) as bigint)] from my_table", "LogicalProject(EXPR$0=[ITEM($0, CAST(*(10, SIN($2))):BIGINT)])\n" + " LogicalTableScan(table=[[hive, default, my_table]])\n", - "SELECT element_at(\"my_table\".\"x\", CAST(10 * SIN(\"my_table\".\"z\") AS BIGINT))\n" + "SELECT element_at(\"my_table\".\"x\", TRY_CAST(10 * SIN(\"my_table\".\"z\") AS BIGINT))\n" + "FROM \"default\".\"my_table\" AS \"my_table\"")) .add(new TrinoToRelTestDataProvider("select * from my_table cross join unnest(x)", "LogicalProject(x=[$0], y=[$1], z=[$2], EXPR$0=[$3])\n" @@ -169,7 +169,7 @@ public Iterator getSupportedSql() { + "FROM \"default\".\"foo\" AS \"foo0\") AS \"t0\" ON 999 = 999")) .add(new TrinoToRelTestDataProvider("select cast('123' as bigint)", "LogicalProject(EXPR$0=[CAST('123'):BIGINT])\n" + " LogicalValues(tuples=[[{ 0 }]])\n", - "SELECT CAST('123' AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")")) + "SELECT TRY_CAST('123' AS BIGINT)\n" + "FROM (VALUES (0)) AS \"t\" (\"ZERO\")")) .add(new TrinoToRelTestDataProvider("select a \"my price\" from \"foo\" \"ORDERS\"", "LogicalProject(MY PRICE=[$1])\n" + " LogicalTableScan(table=[[hive, default, foo]])\n", "SELECT \"foo\".\"a\" AS \"MY PRICE\"\n" + "FROM \"default\".\"foo\" AS \"foo\""))