dbt Tests

expect_compound_columns_to_be_unique

dbt-expectations

·

Model,Seed,Source

·

Uniqueness

How it Works

The expect_compound_columns_to_be_unique test from the dbt-expectations package verifies that the combination of values across a specified set of columns is unique for every row. This is useful when no single column acts as a primary key but a composite key is expected to be unique.

An optional ignore_row_if argument allows you to exclude rows with null values in any or all of the specified columns from the uniqueness check.

Steps and Conditions

  1. Column List: Define the columns that together form the compound key.

  2. Optional Null Handling: Use ignore_row_if to handle rows with null values.

  3. Execution: All column combinations are checked for duplicates.

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

Example Usage: Logistics

A logistics company tracks delivery attempts where the combination of shipment_id and attempt_number should be unique, but neither column alone is a unique identifier.

models:
  - name: delivery_attempts
    tests:
      - dbt_expectations.expect_compound_columns_to_be_unique:
          column_list: ["shipment_id", "attempt_number"]
          ignore_row_if: "any_value_is_missing"
models:
  - name: delivery_attempts
    tests:
      - dbt_expectations.expect_compound_columns_to_be_unique:
          column_list: ["shipment_id", "attempt_number"]
          ignore_row_if: "any_value_is_missing"
models:
  - name: delivery_attempts
    tests:
      - dbt_expectations.expect_compound_columns_to_be_unique:
          column_list: ["shipment_id", "attempt_number"]
          ignore_row_if: "any_value_is_missing"

This prevents duplicate delivery attempt records from corrupting fulfilment tracking reports.

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.