Skip to main content

Utilities for dbt metrics.

Project description

dbt-metric-utils

This tool allows you to query metrics from your dbt semantic model directly from a dbt model through the dbt_metric_utils_materialize macro. One way to look at it is that it revives the metric.calculate() macro from dbt <=v1.5. By having access to this macro, the dbt semantic layer becomes more useful for dbt-core users. You still don't have all the goodness of dbt-cloud semantic layer but it does allow you to get started with connecting your users and BI tools to aggregation tables/views that are directly querying your metrics.

[!TIP] Check out some examples queries here

[!TIP] Browse the dbt docs pages for the example project here

Installation instructions

This project is a Python package that wraps around dbt in the most transparant way I could find. Try it out through the following steps:

  1. Install dbt-metric-utils from Pypi in your project (e.g. pip install dbt-metric-utils)
  2. Run dbt-metric-utils init or dbtmu init. This will install the macro into your project and will make sure that any dbt CLI calls are intercepted and processed in the correct way (check below for explanation)
  3. Introduce a dbt model that calls the dbt_metric_utils_materialize macro.
  4. Continue using dbt as you're used to.

How it works

Any dbt command that doesn't require dbt to compile your project is simply passed directly to dbt (Mode A in the diagram). A dbt invocation that does require compilation (e.g. compile, run, test , etc) is intercepted by the package.

After intercepting we run through the following sequence of steps

  1. Call dbt parse . This will build a partially filled manifest.json from which we can extract all the models, their dependencies, and the raw SQL queries.
  2. Extract all models that contain a dbt_metric_utils_materialize invocation.
  3. Run mf query --explain commands for all the dbt_metric_utils_materialize invocations.
  4. Inject the generated queries by Metricflow as dbt variables in the actual dbt command. If the user ran dbt run , we actually trigger dbt run --vars {<macro_invocation_signature>: <query>}

The passed variables will be a mapping from dbt_metric_utils_materialize invocation signature (e.g. metric=['m1'],dimensions='[dim1']... ) to the generated metric query. The dbt_metric_utils_materialize macro will find that variable at compile time and return it as the macro result.

Along this sequence of steps, we also ensure that the dependency graph in manifest.json is updated correctly. Dbt itself only detects dependencies based on ref and source , not on macros that are external to it.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dbt_metric_utils-0.1.1.tar.gz (12.5 MB view details)

Uploaded Source

Built Distribution

dbt_metric_utils-0.1.1-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file dbt_metric_utils-0.1.1.tar.gz.

File metadata

  • Download URL: dbt_metric_utils-0.1.1.tar.gz
  • Upload date:
  • Size: 12.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.2

File hashes

Hashes for dbt_metric_utils-0.1.1.tar.gz
Algorithm Hash digest
SHA256 3f2d18d4f7f6eb27653509e6ccecb7ee164e1e75e36eddd51ed64c053a551fda
MD5 7b12a18a893bde432fb94b682500a6f3
BLAKE2b-256 ca19cebe756cfed888fc630879478bfcc6149eca3cc49ac33df0de66b8b75cca

See more details on using hashes here.

File details

Details for the file dbt_metric_utils-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for dbt_metric_utils-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e29701164cc47d038d2999a4359161509806495138ec1682b548abb80ecd46e2
MD5 f6216cfa9d1a49d59f6171da9e8501f8
BLAKE2b-256 2ffe6e1098f07bf6309c2073b20b8e4c23ba0fbeabad74e4a85b5b9c93db40cf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page