Skip to main content

event_time

πŸ’‘Did you know...
Available from dbt v1.9 or with the dbt Cloud "Latest" release track.
dbt_project.yml
models:
resource-path:
+event_time: my_time_field
models/properties.yml
models:
- name: model_name
config:
event_time: my_time_field
models/modelname.sql
{{ config(
event_time='my_time_field'
) }}

Definition​

You can configure event_time for a model, seed, or source in your dbt_project.yml file, property YAML file, or config block.

event_time is required for the incremental microbatch strategy and highly recommended for Advanced CI's compare changes in CI/CD workflows, where it ensures the same time-slice of data is correctly compared between your CI and production environments.

Best practices​

Set the event_time to the name of the field that represents the actual timestamp of the event (like account_created_at). The timestamp of the event should represent "at what time did the row occur" rather than an event ingestion date. Marking a column as the event_time when it isn't diverges from the semantic meaning of the column which may result in user confusion when other tools make use of the metadata.

However, if an ingestion date (like loaded_at, ingested_at, or last_updated_at) are the only timestamps you use, you can set event_time to these fields. Here are some considerations to keep in mind if you do this:

  • Using last_updated_at or loaded_at β€” May result in duplicate entries in the resulting table in the data warehouse over multiple runs. Setting an appropriate lookback value can reduce duplicates but it can't fully eliminate them since some updates outside the lookback window won't be processed.
  • Using ingested_at β€” Since this column is created by your ingestion/EL tool instead of coming from the original source, it will change if/when you need to resync your connector for some reason. This means that data will be reprocessed and loaded into your warehouse for a second time against a second date. As long as this never happens (or you run a full refresh when it does), microbatches will be processed correctly when using ingested_at.

Here are some examples of recommended and not recommended event_time columns:

Status
Column nameDescription
βœ… Recommendedaccount_created_atRepresents the specific time when an account was created, making it a fixed event in time.
βœ… Recommendedsession_began_atCaptures the exact timestamp when a user session started, which won’t change and directly ties to the event.
❌ Not recommended_fivetran_syncedThis represents the time the event was ingested, not when it happened.
❌ Not recommendedlast_updated_atChanges over time and isn't tied to the event itself. If used, note the considerations mentioned earlier in best practices.

Examples​

Here's an example in the dbt_project.yml file:

dbt_project.yml
models:
my_project:
user_sessions:
+event_time: session_start_time

Example in a properties YAML file:

models/properties.yml
models:
- name: user_sessions
config:
event_time: session_start_time

Example in sql model config block:

models/user_sessions.sql
{{ config(
event_time='session_start_time'
) }}

This setup sets session_start_time as the event_time for the user_sessions model.

0