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] Previewing Recursive CTE's Throws Error "Recursive CTE in subquery are not supported." #803

Closed
2 tasks done
migueldichoso opened this issue Apr 30, 2024 · 10 comments
Closed
2 tasks done
Labels
type:bug Something isn't working

Comments

@migueldichoso
Copy link

migueldichoso commented Apr 30, 2024

Is this a new bug in dbt-redshift?

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

Current Behavior

When I preview a recursive CTE in dbt cloud IDE, I am getting an error Recursive CTE in subquery are not supported. The same recursive CTE query run successfully with dbt run or dbt build. It also works fine with other datawarehouse such as Snowflake.
image

Expected Behavior

The Preview button should show successful output when previewed the recursive CTE query.
image

Steps To Reproduce

  1. Preview the below recursive query in dbt cloud IDE connected to Redshift.
with recursive daily_dates(upload_day) AS (
select
'2024-01-01'::date as upload_day
union all
select
(upload_day + interval '1 day')::date as upload_day
from daily_dates
where upload_day < current_timestamp
)

select * from daily_dates
  1. The below error should appear.
Runtime Error Database Error in sql_operation inline_query (from remote system.sql) Recursive CTE in subquery are not supported.
Encountered an error: Runtime Error Database Error in sql_operation inline_query (from remote system.sql) Recursive CTE in subquery are not supported.

Relevant log output

  1. The below is log output from the Preview button.
Began running node model.my_new_project.test_recursive_cte
Acquiring new redshift connection 'model.my_new_project.test_recursive_cte'
Began compiling node model.my_new_project.test_recursive_cte
Writing injected SQL for node "model.my_new_project.test_recursive_cte"
Timing info for model.my_new_project.test_recursive_cte (compile): 03:27:57.672761 => 03:27:57.697862
Began executing node model.my_new_project.test_recursive_cte
Using redshift connection "model.my_new_project.test_recursive_cte"
On model.my_new_project.test_recursive_cte: /* {"app": "dbt", "dbt_version": "1.7.13", "profile_name": "user", "target_name": "default", "node_id": "model.my_new_project.test_recursive_cte"} */
  
    select *
    from (
        with recursive daily_dates(upload_day) AS (
select
'2024-01-01'::date as upload_day
union all
select
(upload_day + interval '1 day')::date as upload_day
from daily_dates
where upload_day < current_timestamp
)

select * from daily_dates
    ) as model_limit_subq
    limit 500
Opening a new connection, currently in state init
Redshift adapter: Establishing connection using ssl with `sslmode` set to 'prefer'.To connect without ssl, set `sslmode` to 'disable'.
Redshift adapter: Connecting to redshift with username/password based auth...
Redshift adapter: Redshift error: Recursive CTE in subquery are not supported.
Timing info for model.my_new_project.test_recursive_cte (execute): 03:27:57.699028 => 03:27:57.728949
On model.my_new_project.test_recursive_cte: Close
Database Error in model test_recursive_cte (models/example/test_recursive_cte.sql)
  Recursive CTE in subquery are not supported.
Finished running node model.my_new_project.test_recursive_cte
  1. The below is the log output using dbt run.
03:26:09 SQL status: SUCCESS in 0.0 seconds
03:26:09 Using redshift connection "model.my_new_project.test_recursive_cte"
03:26:09 On model.my_new_project.test_recursive_cte: /* {"app": "dbt", "dbt_version": "1.7.13", "profile_name": "user", "target_name": "default", "node_id": "model.my_new_project.test_recursive_cte"} */

  
    

  create  table
    "dev"."dbt_mdichoso"."test_recursive_cte__dbt_tmp"
    
    
    
  as (
    with recursive daily_dates(upload_day) AS (
select
'2024-01-01'::date as upload_day
union all
select
(upload_day + interval '1 day')::date as upload_day
from daily_dates
where upload_day < current_timestamp
)

select * from daily_dates
  );
03:26:16 SQL status: SUCCESS in 6.0 seconds
03:26:16 Using redshift connection "model.my_new_project.test_recursive_cte"
03:26:16 On model.my_new_project.test_recursive_cte: /* {"app": "dbt", "dbt_version": "1.7.13", "profile_name": "user", "target_name": "default", "node_id": "model.my_new_project.test_recursive_cte"} */
alter table "dev"."dbt_mdichoso"."test_recursive_cte__dbt_tmp" rename to "test_recursive_cte"
03:26:16 SQL status: SUCCESS in 0.0 seconds

Environment

- OS: macOS
- Python: using dbt cloud
- dbt-core: 1.7.13
- dbt-redshift: 1.7.13

Additional Context

No response

@migueldichoso migueldichoso added type:bug Something isn't working triage:product labels Apr 30, 2024
@Caitlin-Syntax
Copy link

Seconding this! I have a few instances where I need to use recursion, and it's annoying not to be able to build/test my work the same way I do for everything else. I get the same error, even though my queries run normally and do not error in the AWS Console/Redshift Query Editor, and dbt is able to build and test the resulting tables successfully.

@jtcohen6
Copy link
Contributor

jtcohen6 commented Jun 3, 2024

Thanks @Caitlin-Syntax! I think we're going to resolve this issue by changing the default behavior of get_show_sql to avoid wrapping in a subquery, given edge cases like this one:

@ashrafkasmipfs
Copy link

Any news on this bug ?
Our pipelines are blocked by this issue :/

@Caitlin-Syntax
Copy link

@ashrafkasmipfs you likely have a different issue if your pipelines are blocked. This only affects the Preview functionality in the Cloud IDE; it does not impact Build, Run, or Test functionality in the Cloud IDE (or elsewhere), and it does not affect Job execution. The problem here is that the Preview function wraps up the compiled SQL as a subquery to apply a LIMIT clause (e.g. SELECT * FROM (your query) as model_limit_subq limit 500), but Build doesn't add the extra wrapper. It could be that you have a macro or something else that's causing your recursive CTE to get wrapped.

@givemelove
Copy link

I'm affected by this issue. We're using BigQuery instead of redshift. Our query runs just fine on BQ, yet I can't run / build the model in DBT. No matter what, it will run a select * FROM with my query below, thus throwing the following error: WITH RECURSIVE is only allowed at the top level of the SELECT, CREATE TABLE AS SELECT, CREATE VIEW, INSERT, EXPORT DATA statements.

select * from (WITH RECURSIVE ...

@Caitlin-Syntax
Copy link

This issue is resolved for me - I just used Preview in the Cloud IDE for a recursive query!

I'm assuming this is a result of the fix for Issue 207 in PR 249.

@brooketran1
Copy link

Not working for me yet. Still getting the error: "Recursive CTE in subquery are not supported."

@Caitlin-Syntax
Copy link

@brooketran1 I saw the changed behavior after switching my Dev Environment from a pretty old version up to Cloud Versionless; I assume this hasn't been fixed in all older versions. If that isn't the issue for you/upgrading isn't an option for you, there are some templates for overriding get_show_sql that you could try in the meantime detailed on these issues:
dbt-labs/dbt-adapters#207
dbt-labs/dbt-core#9600

@dbeatty10
Copy link
Contributor

I believe this was fixed by dbt-labs/dbt-adapters#207 and first available in dbt-adapters 1.3.3 (which requires dbt-core >= 1.8.0), so I'm going to close this as resolved.

Please open a new issue referencing this one if you run into any problems.

Example

Create this file:

models/my_recursive_cte.sql

with recursive daily_dates (upload_day) as (

    select
        -- 3 days ago
        {{ dbt.dateadd(datepart="day", interval=-3, from_date_or_timestamp=dbt.current_timestamp()) }}::date as upload_day

    union all
    
    select
        (upload_day + interval '1 day')::date as upload_day
    from daily_dates
    where upload_day < current_timestamp

)

select * from daily_dates

Run this command:

dbt show --limit 1 --select my_recursive_cte

Get this output for dbt v1.7:

$ dbt show --limit 1 --select my_recursive_cte

17:35:59  Running with dbt=1.7.11
17:36:03  Registered adapter: redshift=1.7.7
17:36:07  
17:36:08  Encountered an error:
Runtime Error
  Database Error in model my_recursive_cte (models/my_recursive_cte.sql)
    Recursive CTE in subquery are not supported.

Get this output for dbt v1.8:

$ dbt show --limit 1 --select my_recursive_cte

17:34:52  Running with dbt=1.8.8
17:34:52  Registered adapter: redshift=1.8.1
17:34:55  
17:34:56  Previewing node 'my_recursive_cte':
| upload_day |
| ---------- |
| 2024-12-02 |

@brooketran1
Copy link

@Caitlin-Syntax @dbeatty10 you're right! updated to the latest version and this is now working, thanks!

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
Projects
None yet
Development

No branches or pull requests

7 participants