Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug]: Error replacing secure view when new column introduced #3135

Closed
1 task
nosterlu opened this issue Oct 14, 2024 · 2 comments
Closed
1 task

[Bug]: Error replacing secure view when new column introduced #3135

nosterlu opened this issue Oct 14, 2024 · 2 comments
Assignees
Labels
bug Used to mark issues with provider's incorrect behavior

Comments

@nosterlu
Copy link

nosterlu commented Oct 14, 2024

Terraform CLI Version

1.8.5

Terraform Provider Version

0.96.0

Terraform Configuration

# First time below was updated fine without the DC column, with DC column added we get an error.

resource snowflake_view view_test {
  database = "MY_DB"
  schema   = "MY_SCHEMA"
  name     = "MY_VIEW"

  comment = ""

  statement  = <<-SQL
    SELECT
      PART
      ,DC
      ,FORECAST_CUSTOMER
      ,STOCK_BALANCE
      ,ORDER_QUE_BALANCE_CLASS_1
      ,ORDER_QUE_BALANCE_CLASS_2_TO_4
      ,STOCK_TAKING_BALANCE
      ,QUANTITY_ORDERED_NOT_INVOICED
      ,QUANTITY_BACK_ORDER_CL_2_TO_4
      ,QUANTITY_BACK_ORDER_CL_1
      ,SUPPLIER_NUMBER
    FROM
      PROD_PSL_DB.PULS.LDC
SQL
  is_secure  = true
}

Category

category:resource

Object type(s)

resource:view

Expected Behavior

The view to be re-created with DC column added

Actual Behavior

terraform ran below SQL, but missed adding the DC column in the first part...

CREATE OR REPLACE SECURE VIEW "MY_DB"."MY_SCHEMA"."MY_VIEW ("PART", "FORECAST_CUSTOMER", "STOCK_BALANCE", "ORDER_QUE_BALANCE_CLASS_1", "ORDER_QUE_BALANCE_CLASS_2_TO_4", "STOCK_TAKING_BALANCE", "QUANTITY_ORDERED_NOT_INVOICED", "QUANTITY_BACK_ORDER_CL_2_TO_4", "QUANTITY_BACK_ORDER_CL_1", "SUPPLIER_NUMBER", "YEAR", "MONTH", "DAY") AS SELECT
  PART
  ,DC
  ,FORECAST_CUSTOMER
  ,STOCK_BALANCE
  ,ORDER_QUE_BALANCE_CLASS_1
  ,ORDER_QUE_BALANCE_CLASS_2_TO_4
  ,STOCK_TAKING_BALANCE
  ,QUANTITY_ORDERED_NOT_INVOICED
  ,QUANTITY_BACK_ORDER_CL_2_TO_4
  ,QUANTITY_BACK_ORDER_CL_1
  ,SUPPLIER_NUMBER
  ,YEAR
  ,MONTH
  ,DAY
FROM
  PROD_PSL_DB.PULS.LDC_HISTORY

SQL compilation error: Invalid column definition list

Steps to Reproduce

Update with this

resource snowflake_view view_test {
  database = "MY_DB"
  schema   = "MY_SCHEMA"
  name     = "MY_VIEW"

  comment = ""

  statement  = <<-SQL
    SELECT
      PART
      ,FORECAST_CUSTOMER
      ,STOCK_BALANCE
      ,ORDER_QUE_BALANCE_CLASS_1
      ,ORDER_QUE_BALANCE_CLASS_2_TO_4
      ,STOCK_TAKING_BALANCE
      ,QUANTITY_ORDERED_NOT_INVOICED
      ,QUANTITY_BACK_ORDER_CL_2_TO_4
      ,QUANTITY_BACK_ORDER_CL_1
      ,SUPPLIER_NUMBER
    FROM
      PROD_PSL_DB.PULS.LDC
SQL
  is_secure  = true
}

then with this

resource snowflake_view view_test {
  database = "MY_DB"
  schema   = "MY_SCHEMA"
  name     = "MY_VIEW"

  comment = ""

  statement  = <<-SQL
    SELECT
      PART
      ,DC
      ,FORECAST_CUSTOMER
      ,STOCK_BALANCE
      ,ORDER_QUE_BALANCE_CLASS_1
      ,ORDER_QUE_BALANCE_CLASS_2_TO_4
      ,STOCK_TAKING_BALANCE
      ,QUANTITY_ORDERED_NOT_INVOICED
      ,QUANTITY_BACK_ORDER_CL_2_TO_4
      ,QUANTITY_BACK_ORDER_CL_1
      ,SUPPLIER_NUMBER
    FROM
      PROD_PSL_DB.PULS.LDC
SQL
  is_secure  = true
}

How much impact is this issue causing?

Medium

Logs

No response

Additional Information

Only way to fix is to first comment out the tables and run terraform to destroy, then to un-comment and run terraform to re-create.

Would you like to implement a fix?

  • Yeah, I'll take it 😎
@nosterlu nosterlu added the bug Used to mark issues with provider's incorrect behavior label Oct 14, 2024
@sfc-gh-jmichalak
Copy link
Collaborator

Hi @nosterlu 👋

I believe this is the same problem, as in #3073 (comment). We've released a fix in v0.97 (release, migration guide). Please upgrade to this version.

@nosterlu
Copy link
Author

Yes the new version worked! Sorry for not testing, I did not see that bugfix in the notes!

@sfc-gh-jmichalak sfc-gh-jmichalak self-assigned this Oct 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Used to mark issues with provider's incorrect behavior
Projects
None yet
Development

No branches or pull requests

2 participants