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] --empty flag generates invalid SQL when running adapter.get_columns_in_relation #213

Closed
2 tasks done
jlucas91 opened this issue May 15, 2024 · 4 comments · Fixed by #257 or #258
Closed
2 tasks done
Assignees
Labels
type:bug Something isn't working as documented type:documentation User documentation requires updating

Comments

@jlucas91
Copy link

Is this a new bug?

  • I believe this is a new bug
  • I have searched the existing issues, and I could not find an existing issue for this bug

Current Behavior

When running the --empty flag introduced in DBT 1.8 adapter.get_columns_in_relation generates and runs an invalid DESCRIBE TABLE statement, halting the run. The statement looks roughly like:

describe table (select * from TABLE_NAME_HERE where false limit 0)

Which generates the error:

  001003 (42000): SQL compilation error:
  syntax error line 1 at position 15 unexpected '('.

Expected Behavior

adapter.get_columns_in_relation should fallback to some reasonable default when running with the --empty flag, or alternatively throws a more intelligible error message.

For our usages, I'm working around it by guarding calls to adapter.get_columns_in_relation behind a check on whether we're running in empty mode. However, this is cumbersome and a bit error prone.

Steps To Reproduce

  1. In DBT 1.8 on Snowflake
  2. Run ./dbt run --empty on a model that uses adapter.get_columns_in_relation
  3. The error will be thrown

Relevant log output

No response

Environment

- OS: Linux
- Python: 3.11
- dbt-adapter: dbt-snowflake

Additional Context

No response

@jlucas91 jlucas91 added type:bug Something isn't working as documented triage:product In Product's queue labels May 15, 2024
@jlucas91
Copy link
Author

May be related to dbt-labs/dbt-core#10139

@jtcohen6
Copy link
Contributor

@jlucas91 Thanks for opening - I think it's actually the same as:

This isn't Snowflake-specific, it would be relevant anywhere we're:

  • templating out {{ relation }}, as a string
  • as the resolved form of a ref/source call
  • in a metadata query (show/describe/etc) where we don't want to access the actual underlying data

I don't think that happens everywhere:

  • e.g. redshift__get_columns_in_relation doesn't template out {{ relation }} as a string, it decomposes it into database/schema/identifier
  • most metadata in BigQuery is via Python SDK
  • create / drop / alter statements don't tend to be used for the direct result of a ref/source call

So while on first read I was worried this was going to be an issue everywhere — I think we just need to do the work of combing through those call sites in our adapters. A reasonable lift, but it feels doable. In the meantime we can document this as a limitation.

@colin-rogers-dbt
Copy link
Contributor

Scope of this fix should also include adding tests to cover some of these edge cases, resolving dbt-labs/dbt-snowflake#1033 and updating maintainer docs

@FishtownBuildBot
Copy link
Collaborator

Opened a new issue in dbt-labs/docs.getdbt.com: dbt-labs/docs.getdbt.com#5734

@mikealfare mikealfare linked a pull request Jul 3, 2024 that will close this issue
4 tasks
@dbeatty10 dbeatty10 changed the title [Bug] --empty flag generates invalid SQL when running adapter.get_columns_in_relation [Bug] --empty flag generates invalid SQL when running adapter.get_columns_in_relation Aug 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type:bug Something isn't working as documented type:documentation User documentation requires updating
Projects
None yet
6 participants