Case Study: creazione di modelli di dati E‑Commerce con dbt
Susan Sun
Freelance Data Scientist
dbt usa tre linguaggi:
Esempio di SQL:
SELECT * FROM ...
Esempio di YAML:
- name: customers
description: A data mart
Esempio di Jinja:
FROM {{ ref('stg_looker__users') }}
Cos'è Jinja in dbt?
Perché è utile?
Esempi di Jinja in dbt:
Referenziare modelli dbt
SELECT *
FROM {{ ref('stg_looker__users') }}
Creare loop
{% 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 #}
Tipi di istruzioni Jinja: set, loop, condizionali (if/else), macro, ecc.
Un'istruzione set crea una variabile e le assegna un valore.
{% set ... %}
{% set country = 'Australia' %}
Uso
customers.sql, come scritto:{% set country = 'Australia' %}
SELECT ...
FROM ...
WHERE country = '{{ country }}'
Codice compilato
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 ha generato i file compilati:
Case Study: creazione di modelli di dati E‑Commerce con dbt