dbt Tests

expect_column_values_to_be_unique

dbt-expectations

·

Column

·

Uniqueness

How it Works

The expect_column_values_to_be_unique test from the dbt-expectations package validates that every value in a column is unique across all rows. This complements the native dbt™ unique test with additional options like row_condition to scope the uniqueness check to a subset of records, and supports grouping for partition-aware uniqueness checks.

Steps and Conditions

  1. Column Selection: Identify the column to check for uniqueness.

  2. Optional Row Condition: Scope the check using row_condition.

  3. Execution: Duplicate values are detected across the filtered rows.

  4. Outcome: Pass if no duplicates exist; fail if any are found.

Example Usage: Identity Management

An identity management system wants to ensure that user email addresses are unique across all active accounts.

models:
  - name: user_accounts
    columns:
      - name: email
        tests:
          - dbt_expectations.expect_column_values_to_be_unique:
              row_condition: "account_status = 'active'"
models:
  - name: user_accounts
    columns:
      - name: email
        tests:
          - dbt_expectations.expect_column_values_to_be_unique:
              row_condition: "account_status = 'active'"
models:
  - name: user_accounts
    columns:
      - name: email
        tests:
          - dbt_expectations.expect_column_values_to_be_unique:
              row_condition: "account_status = 'active'"

This prevents duplicate registrations among active users, protecting login and communication flows.

Interested to Learn More?
Try Out the Free 14-Days Trial

Stop Managing Pipelines. Start Shipping Them.

Join the teams that replaced manual dbt™ workflows with agentic AI. Free to start, no credit card required.

Stop Managing Pipelines. Start Shipping Them.

Join the teams that replaced manual dbt™ workflows with agentic AI. Free to start, no credit card required.

Stop Managing Pipelines. Start Shipping Them.

Join the teams that replaced manual dbt™ workflows with agentic AI. Free to start, no credit card required.

Copyright © 2026 Paradime Labs, Inc. Made with ❤️ in San Francisco ・ London

*dbt® and dbt Core® are federally registered trademarks of dbt Labs, Inc. in the United States and various jurisdictions around the world. Paradime is not a partner of dbt Labs. All rights therein are reserved to dbt Labs. Paradime is not a product or service of or endorsed by dbt Labs, Inc.

Copyright © 2026 Paradime Labs, Inc. Made with ❤️ in San Francisco ・ London

*dbt® and dbt Core® are federally registered trademarks of dbt Labs, Inc. in the United States and various jurisdictions around the world. Paradime is not a partner of dbt Labs. All rights therein are reserved to dbt Labs. Paradime is not a product or service of or endorsed by dbt Labs, Inc.

Copyright © 2026 Paradime Labs, Inc. Made with ❤️ in San Francisco ・ London

*dbt® and dbt Core® are federally registered trademarks of dbt Labs, Inc. in the United States and various jurisdictions around the world. Paradime is not a partner of dbt Labs. All rights therein are reserved to dbt Labs. Paradime is not a product or service of or endorsed by dbt Labs, Inc.