MotherDuck
Connect & Ingest data from / to a MotherDuck database
Setup
The following credentials keys are accepted:
database(required) -> The motherduck database namemotherduck_token(required) -> The service token. See here for instructions on getting it.schema(optional) -> The default schema to use.duckdb_version(optional) -> The CLI version of DuckDB to use. You can also specify the env. variableDUCKDB_VERSION.read_only(optional) -> Whether to open the connection inreadonlymode. Acceptstrueorfalse. Default isfalse.interactive(optional) -> Whether to communicate to the DuckDB CLI via interactive mode instead of reopening the connection each time. Acceptstrueorfalse. Default istrue.motherduck_attach_mode(optional v1.4.24+) -> Whether to set MotherDuck Attach Mode. Acceptsworkspaceorsingle.copy_method(optional) -> the method data is copied from sling into DuckDB. Acceptable values:csv_files,csv_http,arrow_http,named_pipes. Default iscsv_http.max_buffer_size(optional v1.5) -> the max buffer size to use when piping data from DuckDB CLI. Specify this if you have extremely large one-line text values in your dataset. Default is10485760(10MB).
Using sling conns
sling connsHere are examples of setting a connection named MOTHERDUCK. We must provide the type=motherduck property:
$ sling conns set MOTHERDUCK type=motherduck database=my_db motherduck_token=xxxxxxxxxxxx
# Or use url
$ sling conns set MOTHERDUCK url="motherduck://my_db?motherduck_token=xxxxxxxxxxxx"Environment Variable
export MOTHERDUCK='motherduck://my_db?motherduck_token=xxxxxxxxxxxx'
export MOTHERDUCK='{ type: motherduck, database: "my_db", motherduck_token: "xxxxxxxxxxxx" }'Sling Env File YAML
See here to learn more about the sling env.yaml file.
connections:
MOTHERDUCK:
type: motherduck
database: <database>
motherduck_token: <motherduck_token>
schema: <schema>
duckdb_version: '<duckdb_version>'
copy_method: arrow_httpSpecifying a DuckDB version
If you would like to use a specific DuckDB version, you can specify this way:
export DUCKDB_VERSION='0.7.0'If you are facing issues connecting, please reach out to us at [email protected], on discord or open a Github Issue here.
Potential Issue
If you have a .duckdbrc file, which runs commands whenever the DuckDB CLI is invoked, this may interfere with normal Sling operation. If you are facing weird issues and have this file, try again after deleting it.
Last updated
Was this helpful?