tags
- Project file
- Config property
- Config block
resource_type:
- name: resource_name
config:
tags: <string> | [<string>] # Supports single strings or list of strings
# Optional: Add the following specific properties for models
columns:
- name: column_name
tags: <string> | [<string>]
tests:
test-name:
config:
tags: "single-string" # Supports single string
tags: ["string-1", "string-2"] # Supports list of strings
{{ config(
tags="<string>" | ["<string>"]
) }}
Definition
Apply a tag (or list of tags) to a resource.
These tags can be used as part of the resource selection syntax, when running the following commands:
dbt run --select tag:my_tag
— Run all models tagged with a specific tag.dbt build --select tag:my_tag
— Build all resources tagged with a specific tag.dbt seed --select tag:my_tag
— Seed all resources tagged with a specific tag.dbt snapshot --select tag:my_tag
— Snapshot all resources tagged with a specific tag.dbt test --select tag:my_tag
— Indirectly runs all tests associated with the models that are tagged.
Using tags with the +
operator
You can use the +
operator to include upstream or downstream dependencies in your tag
selection:
dbt run --select tag:my_tag+
— Run models tagged withmy_tag
and all their downstream dependencies.dbt run --select +tag:my_tag
— Run models tagged withmy_tag
and all their upstream dependencies.dbt run --select +model_name+
— Run a model, its upstream dependencies, and its downstream dependencies.dbt run --select tag:my_tag+ --exclude tag:exclude_tag
— Run model tagged withmy_tag
and their downstream dependencies, and exclude models tagged withexclude_tag
, regardless of their dependencies.
Examples
Use tags to run parts of your project
Apply tags in your dbt_project.yml
as a single value or a string:
models:
jaffle_shop:
+tags: "contains_pii"
staging:
+tags:
- "hourly"
marts:
+tags:
- "hourly"
- "published"
metrics:
+tags:
- "daily"
- "published"
You can also apply tags to individual resources using a config block:
{{ config(
tags=["finance"]
) }}
select ...
Run resources with specific tags (or exclude resources with specific tags) using the following commands:
# Run all models tagged "daily"
dbt run --select tag:daily
# Run all models tagged "daily", except those that are tagged hourly
dbt run --select tag:daily --exclude tag:hourly
Apply tags to seeds
seeds:
jaffle_shop:
utm_mappings:
+tags: marketing
seeds:
jaffle_shop:
utm_mappings:
+tags:
- marketing
- hourly
Apply tags to saved queries
Usage notes
Tags are additive
Tags accumulate hierarchically. The earlier example would result in:
Model | Tags |
---|---|
models/staging/stg_customers.sql | contains_pii , hourly |
models/staging/stg_payments.sql | contains_pii , hourly , finance |
models/marts/dim_customers.sql | contains_pii , hourly , published |
models/metrics/daily_metrics.sql | contains_pii , daily , published |
Other resource types
Tags can also be applied to sources, exposures, and even specific columns in a resource.
These resources do not yet support the config
property, so you'll need to specify
the tags as a top-level key instead.
version: 2
exposures:
- name: my_exposure
tags: ['exposure_tag']
...
sources:
- name: source_name
tags: ['top_level']
tables:
- name: table_name
tags: ['table_level']
columns:
- name: column_name
tags: ['column_level']
tests:
- unique:
tags: ['test_level']
In the example above, the unique
test would be selected by any of these four tags:
dbt test --select tag:top_level
dbt test --select tag:table_level
dbt test --select tag:column_level
dbt test --select tag:test_level