-
Notifications
You must be signed in to change notification settings - Fork 102
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
set_sql_header and config.sql_header don't do anything. #562
Comments
Related dbt create statements. I don't have time today, but i'll take a look next week at it. |
So i'm not sure exactly what the way forward will be here. How this was implemented is a bit of a block here with respect to table creation. Basically its:
The issue is that the model might have a Essentially it expects that the view creation doesn't have any declares and it's the first statement, which is not the case. If I properly understand the reasoning here it is because dbt is a collection of .sql files, it proxies them into views to allow those to be inserted into a table, primarily because nested CTEs are not supported which would be the case any time someone creates a As an example the file -- xyz.sql
{{
config(
materialized='table',
sql_header="declare @myvar INT = 2;"
)
}}
SELECT @myvar FROM {{ source('my', 'source') into -- this is where the @var will break
DECLARE @myvar INT = 2;
CREATE VIEW dbo.xyz_temporary AS
SELECT @myvar FROM my.source into DECLARE @myvar INT = 2;
SELECT * INTO dbo.xyz FROM dbo.xyz_temporary then finally DROP VIEW IF EXISTS dbo.xyz_temporary You cannot ignore the Its a bit of a catch in that the way a table is created from a .sql file means you need to create a temporary view to prevent it failing on CTEs, but that in turn breaks the ability to have a There is an underlying problem here around the create logic being proxied through a view. So if that could be solved to allow the creation of tables, without needing a view, then this in turn would probably work for tables. I cannot see it working properly for views in any case though. |
Adding one more thought; i'm not sure you could even change the create table logic to fix this. The behaviour of writing sql files that are compiled into your table makes it agnostic about whether its a view or a table, which means, at least on sql server, something that is written as... -- my_cte_model.sql
WITH my_cte AS (
SELECT @myvar as var_col
)
SELECT * FROM my_cte still needs to pass through some sort of a DECLARE @myvar INT = 1;
CREATE TABLE my_cte_model (
var_col INT -- this is also needing to be defined somehow when going down the create table road.
)
INSERT INTO my_cte_model (var_col)
SELECT var_col FROM (
WITH my_cte AS (
SELECT @myvar as var_col
)
SELECT * FROM my_cte
) Otherwise its DECLARE @myvar INT = 1;
SELECT * INTO my_cte_model FROM (
WITH my_cte AS (
SELECT @myvar as var_col
)
SELECT * FROM my_cte
) cte_proxy which breaks due to nested CTEs. |
One work around would be to store that as its own model and join to that using a ref potentially. Certainly not as clean, but one potential option |
When attempting to add a SQL header, nothing is generated. (for reference: https://docs.getdbt.com/reference/resource-configs/sql_header )
this also doesn't work:
The compiled SQL looks like:
The text was updated successfully, but these errors were encountered: