Skip to content

[BUG] Using ephemeral materialization causes all tables to have all null records #33

@jaredx435k2d0

Description

@jaredx435k2d0

Is there an existing issue for this?

  • I have searched the existing issues

Describe the issue

Due to #32, I'm considering ephemeral as the materialization type for netsuite_source, so that I can then create my own staging schema that has all of the tables my connector is bringing in.

The only alternatives I can think of is to try to put them in the same schema, which would cause name conflicts, or to have two staging schemas for the same source, which will be confusing for everyone. Since nobody will directly use the staging models from netsuite_source anyway, I figure it's ok to abstract / hide them away in ephemeral models.

When I try to do this, all fields for all records for all models are null. When I look in my target folder, I can see the generated SQL is explicitly using null as the value for everything.

Is there a way I can use ephemeral as the materialization for netsuite_source?

Relevant error log or model output

target/compiled/netsuite_source/models/netsuite2/stg_netsuite2__transaction_lines.sql:

with  __dbt__cte__stg_netsuite2__transaction_lines_tmp as (


select * 
from [my_db_name_redacted].netsuite_suiteanalytics.transactionline
),base as (

    select * 
    from __dbt__cte__stg_netsuite2__transaction_lines_tmp
),

fields as (

    select
        
    cast(null as boolean) as 
    
    _fivetran_deleted
    
 , 
    cast(null as TIMESTAMP) as 
    
    _fivetran_synced
    
 , 
    cast(null as INT) as 
    
    id
    
 , 
    cast(null as INT) as 
    
    transaction
    
 , 
    cast(null as INT) as 
    
    linesequencenumber
    
 , 
    cast(null as TEXT) as 
    
    memo
    
 , 
    cast(null as INT) as 
    
    entity
    
 , 
    cast(null as INT) as 
    
    item
    
 , 
    cast(null as INT) as 
    
    class
    
 , 
    cast(null as INT) as 
    
    location
    
 , 
    cast(null as INT) as 
    
    subsidiary
    
 , 
    cast(null as INT) as 
    
    department
    
 , 
    cast(null as TEXT) as 
    
    isclosed
    
 , 
    cast(null as TEXT) as 
    
    isbillable
    
 , 
    cast(null as TEXT) as 
    
    iscogs
    
 , 
    cast(null as TEXT) as 
    
    cleared
    
 , 
    cast(null as TEXT) as 
    
    commitmentfirm
    
 , 
    cast(null as TEXT) as 
    
    mainline
    
 , 
    cast(null as TEXT) as 
    
    taxline
    
 


    from base
),

final as (
    
    select
        _fivetran_synced,
        id as transaction_line_id,
        transaction as transaction_id,
        linesequencenumber as transaction_line_number,
        memo,
        entity as entity_id,
        item as item_id,
        class as class_id,
        location as location_id,
        subsidiary as subsidiary_id,
        department as department_id,
        isclosed = 'T' as is_closed,
        isbillable = 'T' as is_billable,
        iscogs = 'T' as is_cogs,
        cleared = 'T' as is_cleared,
        commitmentfirm = 'T' as is_commitment_firm,
        mainline = 'T' as is_main_line,
        taxline = 'T' as is_tax_line

        --The below macro adds the fields defined within your transaction_lines_pass_through_columns variable into the staging model
        





    from fields
)

select * 
from final

Expected behavior

I would expect the CTEs to use the actual fields rather than nulls.

dbt Project configurations

models:

  +persist_docs:
    relation: true
    columns: true

  +copy_grants: true

  netsuite_source:
    +schema: stg_netsuite_suiteanalytics
    +materialized: ephemeral


vars:
  netsuite_data_model: netsuite2
  netsuite2__multibook_accounting_enabled: false
  netsuite2__using_vendor_categories: true

Package versions

packages:
  # - package: calogica/dbt_date
  #   version: 0.7.2 
  #   included as dependency in fivetran/zendesk

  # - package: dbt-labs/dbt_utils
  #   version: 1.0.0 
  #   included as dependency in fivetran/zendesk

  # - package: dbt-labs/dbt_project_evaluator
  #   version: 0.3.0

  # - package: calogica/dbt_expectations
  #   version: 0.8.2

  - package: dbt-labs/codegen
    version: 0.9.0

  - package: fivetran/zendesk
    version: [">=0.10.0", "<0.11.0"]
    # includes dependencies to calogica/dbt_date and dbt-labs/dbt_utils

  - package: fivetran/netsuite
    version: [">=0.7.0", "<0.8.0"]
    # includes dependencies to fivetran/netsuite_source, fivetran/fivetran_utils, dbt-labs/dbt_utils, and dbt-labs/spark_utils

What database are you using dbt with?

snowflake 7.12.3

dbt Version

Core:
  - installed: 1.4.5
  - latest:    1.4.5 - Up to date!

Plugins:
  - snowflake: 1.4.2 - Up to date!

Additional Context

If I switch materialized to view then it all works great.

I'm using Python 3.10.10.

Are you willing to open a PR to help address this issue?

  • Yes.
  • Yes, but I will need assistance and will schedule time during our office hours for guidance
  • No.

Metadata

Metadata

Assignees

No one assigned

    Labels

    type:wontfixThis will not be worked on

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions