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] Model reference and AS with empty run fails #175

Open
2 tasks done
JBExcoffier opened this issue Nov 18, 2024 · 3 comments
Open
2 tasks done

[Bug] Model reference and AS with empty run fails #175

JBExcoffier opened this issue Nov 18, 2024 · 3 comments
Labels
bug Something isn't working triage

Comments

@JBExcoffier
Copy link

JBExcoffier commented Nov 18, 2024

Is this a new bug in dbt-core?

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

Current Behavior

I have a simple model that fails to create using the --empty flag in a run when there is a reference to another (simple) model and a AS statement.

Expected Behavior

Using the --empty flag in the run command should not have any impact in this case.

Steps To Reproduce

bug.sql file in models dir :

SELECT sometable.column FROM {{ref("somemodel")}} AS sometable

that depends on the somemodel.sql file in models dir :

SELECT column FROM table

dbt run --empty produces the following error :
image

I think that the problem comes from the auto generation of the underlying SQL request in the target/run directory :

  create view "db"."schema_dev"."bug__dbt_tmp"
    
    
  as (
    SELECT sometable.column FROM (select * from "db"."schema_dev"."somemodel" where false limit 0) _dbt_limit_subq_somemodel AS sometable
  );

Indeed an automatic table name is added (_dbt_limit_subq_somemodel). And as there is already a AS statement, it makes the whole request fails.

The bug is no more presen when a full run (i.e. without the --empty flag) is performed, as it creates a correct request as follow (target/run) :

  create view "db"."schema_dev"."bug__dbt_tmp"
    
    
  as (
    SELECT sometable.column FROM "db"."schema_dev"."somemodel" AS sometable
  );

Moreover, the problem is not present, with or without the --empty flag, when there is no model dependence. For example as with the following model named nobug.sql :

SELECT sometable.column FROM film AS sometable

It produces a correct request file in the target/run dir (same file generated with or without the --empty flag) :


  create view "db"."schema_dev"."nobug__dbt_tmp"
    
    
  as (
    SELECT sometable.column FROM table AS sometable
  );

Relevant log output

No response

Environment

- OS:Ubuntu 22.04
- Python:3.10.3
- dbt:1.8.5

Which database adapter are you using with dbt?

postgres

Additional Context

It seems to fail with either a ref or a source dependence.

@JBExcoffier JBExcoffier added bug Something isn't working triage labels Nov 18, 2024
@dbeatty10
Copy link
Contributor

Thanks for opening this @JBExcoffier !

This appears related to dbt-labs/dbt-adapters#124 and dbt-labs/dbt-adapters#179.

Transferring to the dbt-postgres repo for further triage.

@dbeatty10 dbeatty10 transferred this issue from dbt-labs/dbt-core Nov 19, 2024
@canutog
Copy link

canutog commented Dec 13, 2024

Hi, I opened an issue #184, that I thought it was related to the new microbatch release.

But it seems this was present in previous versions. I didn't find this issue before creating a new one, sorry about that.
So just FYI, issue #184 is related to this.

@rodrigorabioglio
Copy link

Hello All

The same happens with dbt-databricks/dbt-spark 1.8 and 1.9

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working triage
Projects
None yet
Development

No branches or pull requests

4 participants