Databricks setup
profiles.yml file is for dbt Core users onlyIf you're using dbt Cloud, you don't need to create a profiles.yml file. This file is only for dbt Core users. To connect your data platform to dbt Cloud, refer to About data platforms.
- Maintained by: Databricks
- Authors: some dbt loving Bricksters
- GitHub repo: databricks/dbt-databricks   
- PyPI package: dbt-databricks
- Slack channel: #db-databricks-and-spark
- Supported dbt Core version: v0.18.0 and newer
- dbt Cloud support: Supported
- Minimum data platform version: Databricks SQL or DBR 12+
Installing dbt-databricks
Use pip to install the adapter. Before 1.8, installing the adapter would automatically install dbt-core and any additional dependencies. Beginning in 1.8, installing an adapter does not automatically install dbt-core. This is because adapters and dbt Core versions have been decoupled from each other so we no longer want to overwrite existing dbt-core installations.
Use the following command for installation:
Configuring dbt-databricks
For Databricks-specific configuration, please refer to Databricks configs.
dbt-databricks is the recommended adapter for Databricks. It includes features not available in dbt-spark, such as:
- Unity Catalog support
- No need to install additional drivers or dependencies for use on the CLI
- Use of Delta Lake for all models out of the box
- SQL macros that are optimized to run with Photon
Connecting to Databricks
To connect to a data platform with dbt Core, create the appropriate profile and target YAML keys/values in the profiles.yml configuration file for your Databricks SQL Warehouse/cluster. This dbt YAML file lives in the  .dbt/ directory of your user/home directory. For more info, refer to Connection profiles and profiles.yml.
dbt-databricks can connect to Databricks SQL Warehouses and all-purpose clusters. Databricks SQL Warehouses is the recommended way to get started with Databricks.
Refer to the Databricks docs for more info on how to obtain the credentials for configuring your profile.
Examples
You can use either token-based authentication or OAuth client-based authentication to connect to Databricks. Refer to the following examples for more info on how to configure your profile for each type of authentication.
- Token-based authentication
- OAuth client-based authentication
your_profile_name:
  target: dev
  outputs:
    dev:
      type: databricks
      catalog: CATALOG_NAME #optional catalog name if you are using Unity Catalog]
      schema: SCHEMA_NAME # Required
      host: YOURORG.databrickshost.com # Required
      http_path: /SQL/YOUR/HTTP/PATH # Required
      token: dapiXXXXXXXXXXXXXXXXXXXXXXX # Required Personal Access Token (PAT) if using token-based authentication
      threads: 1_OR_MORE  # Optional, default 1
your_profile_name:
  target: dev
  outputs:
    dev:
      type: databricks
      catalog: CATALOG_NAME #optional catalog name if you are using Unity Catalog
      schema: SCHEMA_NAME # Required
      host: YOUR_ORG.databrickshost.com # Required
      http_path: /SQL/YOUR/HTTP/PATH # Required
      auth_type: oauth # Required if using OAuth-based authentication
      client_id: OAUTH_CLIENT_ID # The ID of your OAuth application. Required if using OAuth-based authentication
      client_secret: XXXXXXXXXXXXXXXXXXXXXXXXXXX # OAuth client secret. # Required if using OAuth-based authentication
      threads: 1_OR_MORE  # Optional, default 1
Host parameters
The following profile fields are always required.
| Field | Description | Example | 
|---|---|---|
| host | The hostname of your cluster. Don't include the http://orhttps://prefix. | YOURORG.databrickshost.com | 
| http_path | The http path to your SQL Warehouse or all-purpose cluster. | /SQL/YOUR/HTTP/PATH | 
| schema | The name of a schema within your cluster's catalog. It's not recommended to use schema names that have upper case or mixed case letters. | MY_SCHEMA | 
Authentication parameters
The dbt-databricks adapter supports both token-based authentication and OAuth client-based authentication.
Refer to the following required parameters to configure your profile for each type of authentication:
| Field | Authentication type | Description | Example | 
|---|---|---|---|
| token | Token-based | The Personal Access Token (PAT) to connect to Databricks. | dapiXXXXXXXXXXXXXXXXXXXXXXX | 
| client_id | OAuth-based | The client ID for your Databricks OAuth application. | OAUTH_CLIENT_ID | 
| client_secret | OAuth-based | The client secret for your Databricks OAuth application. | XXXXXXXXXXXXXXXXXXXXXXXXXXX | 
| auth_type | OAuth-based | The type of authorization needed to connect to Databricks. | oauth | 
Additional parameters
The following profile fields are optional to set up. They help you configure how your cluster's session and dbt work for your connection.
| Profile field | Description | Example | 
|---|---|---|
| threads | The number of threads dbt should use (default is 1) | 8 | 
| connect_retries | The number of times dbt should retry the connection to Databricks (default is 1) | 3 | 
| connect_timeout | How many seconds before the connection to Databricks should timeout (default behavior is no timeouts) | 1000 | 
| session_properties | This sets the Databricks session properties used in the connection. Execute SET -vto see available options | ansi_mode: true | 
Supported Functionality
Delta Lake
Most dbt Core functionality is supported, but some features are only available on Delta Lake.
Delta-only features:
- Incremental model updates by unique_keyinstead ofpartition_by(seemergestrategy)
- Snapshots
Unity Catalog
The adapter dbt-databricks>=1.1.1 supports the 3-level namespace of Unity Catalog (catalog / schema / relations) so you can organize and secure your data the way you like.