Casestudy: e-commercedatamodellen bouwen met dbt
Susan Sun
Freelance Data Scientist
dbt gebruikt drie talen:
Voorbeeld van SQL:
SELECT * FROM ...
Voorbeeld van YAML:
- name: customers
description: A data mart
Voorbeeld van Jinja:
FROM {{ ref('stg_looker__users') }}
Wat is dbt Jinja?
Waarom is het handig?
Voorbeelden van Jinja in dbt:
Verwijzen naar dbt-modellen
SELECT *
FROM {{ ref('stg_looker__users') }}
Lussen maken
{% for column in ['col1', 'col2'] %}
SELECT {{ column }}
FROM table_name
{% endfor %}
{%...%} {% set order_statuses = ['Shipped', 'Complete', 'Processing'] %}
{{...}} SELECT * FROM {{ ref('stg_looker__users') }}
{# #} {# This is a comment #}
Types Jinja-statements: set, loop, conditioneel (if/else), macros, enz.
Een set-statement maakt een variabele en kent een waarde toe.
{% set ... %}
{% set country = 'Australia' %}
Gebruik
customers.sql, zoals geschreven:{% set country = 'Australia' %}
SELECT ...
FROM ...
WHERE country = '{{ country }}'
Gecompileerde code
dbt compile -s customers.sql:
SELECT ...
FROM ...
WHERE country = 'Australia'
dbt compile -s customers.sql:Running with dbt=1.8.4
...
Compiled node 'customers' is:
WITH customer_base AS (
SELECT
...
FROM "dbt"."main"."stg_looker__users"
WHERE country = 'Australia'
)
...
/target/compileddbt compile heeft gecompileerde bestanden gemaakt:
Casestudy: e-commercedatamodellen bouwen met dbt