From dc807048deb82a11d05a23e57a7c8b2bc881cc68 Mon Sep 17 00:00:00 2001 From: Gennadiy Anisimov Date: Thu, 4 Jan 2024 12:03:49 +0300 Subject: [PATCH] Handle ADD COLUMN with DEFAULT for spark dialect See WRONG_COLUMN_DEFAULTS_FOR_DELTA_ALTER_TABLE_ADD_COLUMN_NOT_SUPPORTED and WRONG_COLUMN_DEFAULTS_FOR_DELTA_FEATURE_NOT_ENABLED error classes in Databricks for details. --- inst/csv/replacementPatterns.csv | 1 + tests/testthat/test-translate-spark.R | 5 +++++ 2 files changed, 6 insertions(+) diff --git a/inst/csv/replacementPatterns.csv b/inst/csv/replacementPatterns.csv index 15e05147..35c81581 100644 --- a/inst/csv/replacementPatterns.csv +++ b/inst/csv/replacementPatterns.csv @@ -1130,6 +1130,7 @@ spark,(SELECT DISTINCT TOP @([0-9]+)rows @a),(SELECT DISTINCT @a LIMIT @rows) spark,"WITH @cte AS (SELECT @s1 '@literal' @s2)","WITH @cte AS (SELECT @s1 CAST('@literal' as STRING) @s2)" spark,UPDATE STATISTICS @a;, spark,"SELECT @columns FROM (@a) @x,(@b) @y;","SELECT @columns FROM (@a) @x cross join (@b) @y;" +spark,"ALTER TABLE @table ADD COLUMN @([\w_-]+)column @type DEFAULT @default;","ALTER TABLE @table ADD COLUMN @column @type; \nALTER TABLE @table SET TBLPROPERTIES('delta.feature.allowColumnDefaults' = 'supported'); \nALTER TABLE @table ALTER COLUMN @column SET DEFAULT @default;" sqlite extended,"IIF(@condition, @whentrue, @whenfalse)","CASE WHEN @condition THEN @whentrue ELSE @whenfalse END" sqlite extended,"ROUND(@a,@b)","ROUND(CAST(@a AS REAL),@b)" sqlite extended,+ '@a',|| '@a' diff --git a/tests/testthat/test-translate-spark.R b/tests/testthat/test-translate-spark.R index 76daeb1a..b5e12781 100644 --- a/tests/testthat/test-translate-spark.R +++ b/tests/testthat/test-translate-spark.R @@ -431,3 +431,8 @@ test_that("translate sql server -> spark temp table field ref", { sql <- translate("SELECT #tmp.name FROM #tmp;", targetDialect = "spark", tempEmulationSchema = "ts") expect_equal_ignore_spaces(sql, sprintf("SELECT %stmp.name FROM ts.%stmp;", getTempTablePrefix(), getTempTablePrefix())) }) + +test_that("translate sql server -> spark add column with default", { + sql <- translate("ALTER TABLE mytable ADD COLUMN mycol int DEFAULT 0;", targetDialect = "spark") + expect_equal_ignore_spaces(sql, "ALTER TABLE mytable ADD COLUMN mycol int; \n ALTER TABLE mytable SET TBLPROPERTIES('delta.feature.allowColumnDefaults' = 'supported'); \n ALTER TABLE mytable ALTER COLUMN mycol SET DEFAULT 0;") +})