Skip to content

memsql/dbt-singlestore

Repository files navigation

dbt logo

dbt

dbt enables data analysts and engineers to transform their data using the same practices that software engineers use to build applications.

dbt is the T in ELT. Organize, cleanse, denormalize, filter, rename, and pre-aggregate the raw data in your warehouse so that it's ready for analysis.

dbt-singlestore

dbt-singlestore enables dbt to work with SingleStore. For more information on using dbt with SingleStore, consult the docs.

Installation

dbt-singlestore is available on PyPI. To install the latest version via pip, run:

pip install dbt-singlestore

Configuring your profile

A sample profile can be found in sample_profiles.yml. It is a standard profile for SQL data sources in dbt. In SingleStore, like in MySQL, database and schema denote the same concept. In dbt, and also in a number of DBMS (e.g. Postgres) schema has a different meaning (a namespace within a database). Therefore, schema must be specified in dbt profile, but it won't affect database objects by default. However, it can be used as a prefix for table names, as outlined in dbt docs for SingleStore profile.

Supported Features

Category Feature Supported? Tested?
Materializations Table Yes Yes
  View Yes Yes
  Incremental Yes Yes
  Ephemeral Yes Yes
Resources Seeds Yes Yes
  Sources Yes Yes
  Testing - Bespoke Yes Yes
  Testing - Generic Yes Yes
  dbt Documentation Yes Yes
  Snapshots Yes Yes
Administration Hooks Yes Yes
Models Custom schema Limited* Yes
  • Custom schemas can be defined in a project models, but they can only serve as a modification to the prefix of the corresponding table names.

  • SSL connection would be automatically established by dbt-singlestore for SingleStore users created with 'Require SSL' flag.

Testing and supported versions

Default dbt tests and jaffle_shop project are used to check the adapter functionality. Development overview has a section "Run tests" which contains instructions on running the tests. Currently, the tests have been successfully run for the following product versions:

SingleStore dbt-core dbt-tests-adapter
9.0.9 1.10.13 1.19.1
8.9.10 1.10.13 1.19.1
8.7.43 1.9.9 1.17.0
8.7.43 1.8.13 1.11.0
8.5.16 1.7.15 1.7.15
8.5.16 1.6.13 1.6.13
8.1.1 1.6.0 1.6.0
8.1.1 1.5.0 1.5.0
8.1.1 1.4.0 1.4.0
8.1.1 1.3.0 1.3.0
7.8.29 1.2.2 1.2.2
SingleStore dbt-core pytest-dbt-adapter
7.8.3 1.1.1 0.6.0
7.6.6 1.0.1 0.6.0
7.5.12 1.0.1 0.6.0

To use this adapter, SingleStore must be upgraded to the version 8.5 or newer.

Contributors

We thank Doug Beatty who build an adapter for mysql which has been used to build an initial version of this adapter.

Contribute

About

No description, website, or topics provided.

Resources

License

Contributing

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages