Audits are SQL queries that verify data quality. If an audit returns rows, something is wrong. SQLBuild runs audits before data is promoted to the target table, so bad data never reaches production.Documentation Index
Fetch the complete documentation index at: https://docs.sqlbuild.com/llms.txt
Use this file to discover all available pages before exploring further.
How audits work
An audit is a SELECT query that returns rows that violate a condition. Zero rows means the audit passes. Any rows returned means a failure. Forerror severity audits:
- Full table builds: SQLBuild materializes into a staging table, runs audits against it, and only promotes to the target if all audits pass. If any fail, the staging table is kept for inspection and the production table is untouched.
- Incremental models: Delta-phase audits validate each batch before DML is applied. If an audit fails, the batch is not applied.
warn severity audits, the build continues and the failure is reported in the output.
Generic audits
Generic audits are reusable SQL templates defined underaudits/generic/. They use parameter substitution to work across any model or column.
Defining generic audits
@column and @model parameters are substituted at compile time based on where the audit is attached. Custom parameters like @expression and @'values' are passed from the schema YAML.
Attaching generic audits
Attach audits to models inschema.yml:
@column. Model-level audits use custom parameters like @expression.
Singular audits
Singular audits are standalone SQL files underaudits/ (outside the generic/ directory) that reference models directly. They’re useful for one-off checks that don’t fit a reusable template.
__ref() calls in the query. If the audit references a single model, it attaches to that model. If it references multiple models, SQLBuild attaches it to the latest (most downstream) model in the DAG. If attachment can’t be inferred, the audit runs at the end of the build.
Source audits
Sources support the same audit system as models. Audits attached to sources run before any dependent model is built:error severity fails, all downstream models that depend on that source are blocked. This lets you catch data quality issues at the source before any transformations run.
Severity
| Severity | Behavior |
|---|---|
error | Blocks the build. Staging table is not promoted, DML is not applied. |
warn | Reports a warning but allows the build to continue. |
sqlbuild_project.yml:
Run scope
Audits on incremental models can run at different lifecycle phases:| Scope | Behavior |
|---|---|
final | Run once after materialization against the target table (default). |
delta_and_final | Run against each delta batch before DML, then again against the target after all batches complete. |
error severity block DML before the target is updated. This is visible in the build output as audit (d) for delta-phase and audit (f) for final-phase:
4/4 indicates the audit passed for all 4 microbatch batches.
If a model is not incremental, delta_and_final degrades to final automatically.

