Creating a model in dbt helps you turn raw data into clean, organized tables. This makes it easier to analyze and understand your data.
Creating your first model in dbt
Start learning this pattern below
Jump into concepts and practice - no test required
select column1, column2, aggregate_function(column3) as new_column from source_table where condition
This is a basic SQL SELECT statement used inside a dbt model file.
Each model is a SQL file that creates a table or view in your data warehouse.
select * from raw.customersselect customer_id, count(order_id) as total_orders from raw.orders where order_status = 'completed' group by customer_id
select customer_id, upper(customer_name) as customer_name_upper from raw.customers
This simple dbt model selects active users from the raw.users table.
Save this SQL in your dbt project's models folder as my_first_model.sql. When you run dbt run, it will create a table or view with this data.
-- File: models/my_first_model.sql
select
id,
name,
created_at
from raw.users
where active = trueModel files must be saved in the models folder of your dbt project.
Run dbt run to build your models and create tables or views in your data warehouse.
Use simple SQL first, then add complexity as you learn.
dbt models are SQL files that transform raw data into clean tables.
Save your SQL code in the models folder and run dbt run to create the model.
Start with simple SELECT statements to build your first model.
Practice
Solution
Step 1: Understand the role of dbt models
dbt models are SQL files that transform raw data into clean tables for analysis.Step 2: Compare options with this role
Only To transform raw data into clean, usable tables describes transforming raw data into clean tables, which matches the purpose of dbt models.Final Answer:
To transform raw data into clean, usable tables -> Option DQuick Check:
dbt model purpose = transform raw data [OK]
- Confusing models with dashboards
- Thinking models store raw data unchanged
- Assuming models are Python scripts
Solution
Step 1: Recall dbt model syntax
A dbt model is a SQL SELECT statement saved as a .sql file in the models folder.Step 2: Evaluate each option
SELECT * FROM raw_data is a simple SELECT statement, which is the correct way to define a model. Options B, C, and D use incorrect syntax or commands not used in dbt model files.Final Answer:
SELECT * FROM raw_data -> Option AQuick Check:
dbt model = simple SELECT statement [OK]
- Using CREATE MODEL syntax (not valid in dbt)
- Trying to run dbt commands inside SQL files
- Using INSERT statements instead of SELECT
models/my_first_model.sql:
SELECT id, name FROM raw_customers WHERE active = trueWhat will be the output when you run
dbt run?Solution
Step 1: Understand what dbt run does
Runningdbt runexecutes model SQL files and creates tables or views with the model name.Step 2: Analyze the model SQL
The model selects id and name from raw_customers where active is true, so the output table will contain only active customers.Final Answer:
A new table or view named my_first_model with active customers only -> Option CQuick Check:
dbt run creates model tables = filtered active customers [OK]
- Expecting CREATE TABLE in model SQL
- Thinking dbt deletes source tables
- Believing dbt run does nothing
models/customer_summary.sql:
SELECT customer_id, order_id, COUNT(*) AS orders_count FROM orders GROUP BY customer_idWhen you run
dbt run, you get an error. What is the most likely cause?Solution
Step 1: Recall GROUP BY rules
When using GROUP BY, all non-aggregated columns in SELECT must either be aggregated or included in GROUP BY.Step 2: Analyze the SELECT and GROUP BY columns
SELECT has customer_id (in GROUP BY), order_id (neither aggregated nor grouped), COUNT(*) (aggregated). Thus, GROUP BY does not match SELECT columns.Final Answer:
The GROUP BY column does not match the SELECT columns -> Option BQuick Check:
GROUP BY must include all non-aggregated SELECT columns [OK]
- Forgetting to include non-aggregated columns in GROUP BY
- Assuming semicolon is required
- Saving model outside models folder
Solution
Step 1: Understand filtering on aggregated values
To filter groups by aggregated values, use HAVING with the aggregate function, not WHERE.Step 2: Analyze each option
SELECT category, SUM(sales) AS total_sales FROM sales_data GROUP BY category HAVING total_sales > 1000 uses HAVING total_sales > 1000, but total_sales is an alias and cannot be used directly in HAVING in many SQL dialects. SELECT category, SUM(sales) AS total_sales FROM sales_data GROUP BY category HAVING SUM(sales) > 1000 uses HAVING SUM(sales) > 1000, which is correct. Options B and D incorrectly use WHERE with aggregate functions, which is invalid.Final Answer:
SELECT category, SUM(sales) AS total_sales FROM sales_data GROUP BY category HAVING SUM(sales) > 1000 -> Option AQuick Check:
Use HAVING with aggregate functions to filter groups [OK]
- Using WHERE to filter aggregated results
- Using alias names in HAVING clause
- Forgetting GROUP BY when aggregating
