ChangelogBook a demoSign up

Warehouse tables reference

Hightouch creates and manages tables in your data warehouse to power change data capture, sync logging, audience snapshots, journeys, identity resolution, and more. This page is a single reference for all of these tables: which schema they belong to, which feature creates them, and how you should (and shouldn't) use them.

Usage guidance

Hightouch writes these tables to your warehouse for observability, debugging, and lightweight reporting. Before building on top of them, keep the following in mind.

  • Ad-hoc debugging and auditing. Query sync logs to investigate failed rows, inspect audience membership changes, or trace a user's journey path.
  • Lightweight reporting. Build dashboards on top of sync run metadata, audience snapshots, or identity resolution outputs to monitor Hightouch activity.
  • Analytics and activation with Identity Resolution outputs. The _resolved, _resolved_identifiers, and _golden_records tables are explicitly designed for downstream use. You can query them directly, register them as dbt sources, or sync from them.
  • Wiring tables into production workflows. Don't build business-critical pipelines that depend on these tables without . Table schemas may change as Hightouch evolves, and we don't guarantee schema stability for all tables.
  • Writing to Hightouch-managed tables. Never insert, update, or delete rows in the hightouch_planner schema (especially JOURNEY_LOG tables and _plan/_rejections tables). These tables are actively used during sync and journey execution — modifying them can cause unexpected behavior.
  • Depending on internal state tables. Tables prefixed with IDR_ or IDR_BACKUP_ are internal to Identity Resolution. Don't query or reference them in pipelines — they can change without notice.

Documenting a table here doesn't mean Hightouch is committing to a stable schema contract. If you want to build durable integrations on top of these tables, so we can help you find the right approach.


Schemas overview

Hightouch uses up to three schemas in your warehouse, depending on which features you enable:

SchemaPurposeCreated when
hightouch_plannerChange data capture, audience snapshots, journey logs, Identity Resolution outputs, AI Decisioning tablesLightning sync engine is enabled
hightouch_auditWarehouse Sync Logs, holdout group logs, journey views, data extraction reportsLightning sync engine is enabled; individual features populate specific tables
Custom (per Events source)Event data (Hightouch Events); schema name is configurableAn Events source writes to a warehouse destination

hightouch_planner schema

Lightning sync engine (CDC)

These tables are created automatically when the Lightning sync engine is enabled. They're required for syncs using the Lightning engine.

TableKey columnsDescription
*_planStores a model's query results for a sync run, used to compute row-level diffs. Table names change with every run.
*_rejectionsStores rows rejected during a sync run. Table names change with every run.

Hightouch only keeps the two most recent pairs of _plan and _rejections tables per sync. Because table names change with every run, Hightouch requires write access to the entire schema.

Don't delete tables from hightouch_planner. Removing CDC tables breaks change data capture and requires a full resync to recover.

For full details, see Lightning sync engine — Warehouse schemas.

Audience snapshots

Optional — must be enabled on the source's Sync Logs tab. See Audience snapshots.

TableKey columnsDescription
audience_membershipht_row_id, ht_audience_id, ht_timestamp, ht_event_type, ht_split_groupTracks audience membership changes over time. Each row records an enter or exit event for a member.

Journey tables

Created automatically when a journey is active. See Journeys — Journey logs.

Don't write to JOURNEY_LOG tables. They're actively used during journey execution — inserting, updating, or deleting rows can cause the journey to behave unexpectedly.

The journey_id in table names is the journey's UUID with dashes removed.

JOURNEY_LOG

JOURNEY_LOG_<journey_id> logs the progress of all rows through a given journey. Each time a row enters the journey, moves from one node to another, or exits the journey, Hightouch creates an entry in this table. Since a row can enter a journey more than once, the row_instance_id column uniquely identifies each entry instance as it moves through the journey.

Resetting a journey clears its log table.

ColumnTypeDescription
row_idstringThe primary key from the journey's parent model that this row represents.
row_instance_idstringA UUID to uniquely identify a row_id each time it enters the journey.
run_idstringThe ID of the journey run that executed this operation. Internal detail.
from_node_idstringThe node this action originates from. For moves or exits, it's the node the row moved or exited from. For entries, it's NULL.
to_node_idstringThe node this action targets. For moves and entries, it's the node the row moved into. For exits, it's NULL.
timestamptimestampThe effective timestamp of this operation. This doesn't always represent the actual time the operation occurred — for example, if a row moved due to an event, this is the event timestamp rather than when the warehouse query ran.
event_typestringThe type of event: moved-to-node, entered-journey, exited-journey-by-criteria, or exited-journey.

JOURNEY_METADATA

JOURNEY_METADATA_<journey_id> contains the journey's graph structure and customer-defined node names. Updated each time a change is saved to the journey.

ColumnTypeDescription
journey_idtextThe ID of the journey.
journey_nametextThe customer-defined name of the journey.
node_nametextThe customer-defined name of the node.
node_typetextThe node type: entry-cohort, entry-event, sync, segments, segment-branch, time-delay, splits, split-branch, wait-until-event, wait-until-event-branch.
node_idtextThe ID of the journey node.
to_nodestext[]An array of the outbound node IDs from the given node.

JOURNEY_CONTEXT_LOG

JOURNEY_CONTEXT_LOG_<journey_id> logs the result of journey context variables for each row.

ColumnTypeDescription
row_idstringThe primary key from the journey's parent model that this row represents.
row_instance_idstringA UUID to uniquely identify a row_id each time it enters the journey.
run_idstringThe ID of the journey run that executed this operation. Internal detail.
node_idstringThe ID of the journey node.
entered_attimestampWhen the row entered the "set a variable" node.
inserted_attimestampUsed for prioritizing when multiple context nodes assign the same variable. The most recent value is used.
[variable_name]dynamicOne dynamic column per context variable. The type depends on the variable's type.

Identity Resolution outputs

Created automatically when an identity graph runs. See Identity Resolution for details.

TableKey columnsDescription
<output_prefix>_resolvedht_id, source, primary_key, latest_timestampMaps every input row to a resolved identity.
<output_prefix>_resolved_identifiersht_id, identifier, value, first_timestamp, last_timestamp, countAll identifier values associated with each resolved identity.
<output_prefix>_unresolvedInput rows that couldn't be processed, typically due to duplicate primary keys.
<output_prefix>_golden_recordsht_id, plus one column per configured fieldOne row per identity with canonical field values. Only created when Golden Record is enabled.

These four output tables are designed for your use. You can safely query them, reference them in dbt, or build views on top of them. For long-term stability, we recommend creating a view or derived table rather than transforming them in place.

Identity Resolution internal state

TableDescription
IDR_* / IDR_BACKUP_*Internal tables for incremental processing and graph consistency.

Don't query or modify these tables. They're internal implementation details and can change without notice.

AI Decisioning

Created automatically per agent when using Hightouch-assigned groups. See AI Decisioning — Group assignment.

TableKey columnsDescription
de_user_experiment_groups_<agent_id>user_id, user_hash, experiment, first_seen_at, last_seen_atTracks which experiment bucket (treatment, holdout, customer_managed) each user belongs to over time.

hightouch_audit schema

Warehouse Sync Logs

Optional — must be enabled per source or per sync. See Warehouse Sync Logs.

TableKey columnsDescription
sync_changelogsync_id, row_id, op_type, status, failure_reason, fieldsA log of every operation across all sync runs. Each synced row gets one entry per run.
sync_snapshotsync_id, row_id, op_type, status, failure_reason, fieldsThe latest status of each row across all syncs. Replaced after each run.
sync_runssync_id, sync_run_id, model_name, started_at, finished_at, statusMetadata for each sync run, including row counts for planned, attempted, succeeded, and failed operations.

Holdout group logs

Optional — requires a feature flag and must be enabled on the source's Sync Logs tab. See Experiments — Holdout group logs.

TableKey columnsDescription
audience_holdoutsync_id, sync_run_id, model_id, row_id, fields, split_groupLogs rows excluded from a sync due to holdout group membership, for post-campaign analysis.

Journey views

Created automatically when journeys are active. These are read-only views that combine all per-journey tables into a single workspace-level view. Use these views rather than querying individual JOURNEY_LOG and JOURNEY_METADATA tables for warehouse reporting.

Find your workspace slug under Settings → Workspace → Workspace slug. Replace dashes with underscores in the slug when querying (for example, my-workspace becomes my_workspace).

JOURNEY_LOG_VIEW

JOURNEY_LOG_VIEW_<workspace_slug> combines all JOURNEY_LOG tables into a single view of row movement across all journeys. Updated each time a journey is added or removed from the workspace.

ColumnTypeDescription
source_tablestringThe name of the table this row came from: journey_log_<journey_id>.
row_idstringThe primary key from the journey's parent model that this row represents.
row_instance_idstringA UUID to uniquely identify a row_id each time it enters the journey.
run_idstringThe ID of the journey run that executed this operation. Internal detail.
from_node_idstringThe node this action originates from. For moves or exits, it's the node the row moved or exited from. For entries, it's NULL.
to_node_idstringThe node this action targets. For moves and entries, it's the node the row moved into. For exits, it's NULL.
timestamptimestampThe effective timestamp of this operation. This doesn't always represent the actual time the operation occurred — for example, if a row moved due to an event, this is the event timestamp rather than when the warehouse query ran.
event_typestringThe type of event: moved-to-node, entered-journey, exited-journey-by-criteria, or exited-journey.
journey_idtextThe ID of the journey.

JOURNEY_METADATA_VIEW

JOURNEY_METADATA_VIEW_<workspace_slug> combines all JOURNEY_METADATA tables into a single view of node structures across all journeys. Updated each time a journey runs.

ColumnTypeDescription
source_tablestringThe name of the table this row came from: journey_metadata_<journey_id>.
journey_idtextThe ID of the journey.
journey_nametextThe customer-defined name of the journey.
node_nametextThe customer-defined name of the node.
node_typetextThe node type: entry-cohort, entry-event, sync, segments, segment-branch, time-delay, splits, split-branch, wait-until-event, wait-until-event-branch.
node_idtextThe ID of the journey node.
to_nodestext[]An array of the outbound node IDs from the given node.

Data extraction

Created automatically when data extraction is enabled for a destination. See Data extraction.

TableKey columnsDescription
{destination-type}_{destination-id}_audiencesVaries by ad platformOne table per enabled destination. Schema mirrors the ad platform's API response.
external_audiences_metadata_v1 (view)ad_account_id, audience_id, audience_name, audience_size, ht_fetched_atA combined, standardized view across all destination tables.

Events schema

Hightouch Events writes event data into a configurable schema — not hightouch_planner or hightouch_audit. The schema name defaults to an auto-generated value based on the event source but can be configured in destination settings. Tables are created automatically when an Events source writes to a warehouse destination.

TableKey columnsDescription
identifiesid, anonymous_id, user_id, <traits>, timestampAll identify events. Trait keys become separate columns.
tracksid, anonymous_id, user_id, event, event_text, timestampAll track events.
Per-event tablesVariesA separate table for each track event type, with event properties as columns. Can be disabled.
pagesid, anonymous_id, user_id, <properties>, timestampAll page events.
screensid, anonymous_id, user_id, <properties>, timestampAll screen events.
groupsid, anonymous_id, user_id, group_id, <traits>, timestampAll group events.

For the full column-level schema, see Events warehouse schema.

Ready to get started?

Jump right in or a book a demo. Your first destination is always free.

Book a demoSign upBook a demo

Need help?

Our team is relentlessly focused on your success. Don't hesitate to reach out!

Feature requests?

We'd love to hear your suggestions for integrations and other features.

Privacy PolicyTerms of Service

Last updated: Jun 15, 2026

On this page
  • Usage guidance
  • Recommended uses
  • Not recommended
  • Schemas overview
  • hightouch_planner schema
  • Lightning sync engine (CDC)
  • Audience snapshots
  • Journey tables
  • Identity Resolution outputs
  • Identity Resolution internal state
  • AI Decisioning
  • hightouch_audit schema
  • Warehouse Sync Logs
  • Holdout group logs
  • Journey views
  • Data extraction
  • Events schema

Was this page helpful?