Skip to main content

DuckDB SQLAlchemy dialect for DuckDB and MotherDuck

Project description

duckdb-sqlalchemy

PyPI version PyPI Downloads codecov

duckdb-sqlalchemy is a DuckDB SQLAlchemy dialect for DuckDB and MotherDuck. It supports SQLAlchemy Core and ORM APIs for local DuckDB and MotherDuck connections.

For new projects, this repository is the recommended dialect when you want production-oriented defaults, explicit MotherDuck guidance, and a clear migration path from older package names.

The dialect handles pooling defaults, bulk inserts, type mappings, and cloud-specific configuration.

Why choose duckdb-sqlalchemy today

  • SQLAlchemy compatibility: Core, ORM, Alembic, and reflection.
  • MotherDuck support: Token handling, attach modes, session hints, and read scaling helpers.
  • Operational defaults: Pooling defaults, transient retry for reads, and bulk insert optimization via Arrow/DataFrame registration.
  • Active release cadence: Tracks current DuckDB releases with a long-term support posture.
Area duckdb-sqlalchemy (this repo) duckdb_engine
Package/module name duckdb-sqlalchemy / duckdb_sqlalchemy duckdb-engine / duckdb_engine
SQLAlchemy driver URL duckdb:// duckdb://
MotherDuck workflow coverage Dedicated URL helper (MotherDuckURL), connection guidance, and examples No dedicated MotherDuck usage section in the upstream README
Operational guidance Documented pooling defaults, read-scaling helpers, and bulk insert patterns Basic configuration guidance in upstream README
Migration path Explicit migration guide from older package names Migration to this package is documented in this repo
Project direction Release policy, changelog, roadmap, and docs site are maintained here Upstream README focuses on the core driver usage

Coming from duckdb_engine?

If you already use duckdb-engine, migration is straightforward:

  • keep the SQLAlchemy URL scheme (duckdb://)
  • install duckdb-sqlalchemy
  • switch imports to duckdb_sqlalchemy

See the full guide: docs/migration-from-duckdb-engine.md.

Project lineage

This project is a heavily modified fork of Mause/duckdb_engine and continues to preserve upstream history in CHANGELOG.md.

Current direction in this repository:

  • package and module rename to duckdb-sqlalchemy / duckdb_sqlalchemy
  • production-oriented defaults for local DuckDB and MotherDuck deployments
  • docs-first maintenance with versioned release notes and a published docs site

Compatibility

Component Supported versions
Python 3.9+
SQLAlchemy 2.0.45+ (CI-tested: 2.0.45, 2.0.49)
DuckDB 0.5.0+ (CI-tested currently: 1.1.3 to 1.5.2)

Install

pip install duckdb-sqlalchemy

Quick start (DuckDB)

from sqlalchemy import Column, Integer, String, create_engine
from sqlalchemy.orm import declarative_base, Session

Base = declarative_base()


class User(Base):
    __tablename__ = "users"

    id = Column(Integer, primary_key=True)
    name = Column(String)


engine = create_engine("duckdb:///:memory:")
Base.metadata.create_all(engine)

with Session(engine) as session:
    session.add(User(name="Ada"))
    session.commit()
    assert session.query(User).one().name == "Ada"

Quick start (MotherDuck)

export MOTHERDUCK_TOKEN="..."
from sqlalchemy import create_engine

engine = create_engine("duckdb:///md:my_db")

MotherDuck uses the md: database prefix. Access tokens are picked up from MOTHERDUCK_TOKEN (or motherduck_token) automatically. OAuth flows can pass motherduck_oauth_token through the URL or connect_args["config"]. If a token has special characters, URL-escape it or pass it via connect_args.

Connection URLs

DuckDB URLs follow the standard SQLAlchemy shape:

duckdb:///<database>?<config>

Examples:

duckdb:///:memory:
duckdb:///analytics.db
duckdb:////absolute/path/to/analytics.db
duckdb:///md:my_db?attach_mode=single&access_mode=read_only&session_name=team-a

Use the URL helpers to build connection strings safely:

from duckdb_sqlalchemy import URL, MotherDuckURL

local_url = URL(database=":memory:", memory_limit="1GB")
md_url = MotherDuckURL(database="md:my_db", attach_mode="single")

Configuration and pooling

This dialect defaults to SingletonThreadPool for exact :memory:, QueuePool for named in-memory, empty database URLs, and local file paths, and NullPool for MotherDuck connections. You can still override pooling explicitly. For long-lived MotherDuck pools, use the performance helper or configure QueuePool, pool_pre_ping, and pool_recycle.

See docs/configuration.md and docs/motherduck.md for detailed guidance.

For manual WAL syncs after SQLAlchemy writes, prefer the explicit duckdb_sqlalchemy.checkpoint(conn) helper over issuing raw CHECKPOINT through a transactional SQLAlchemy connection.

Documentation

Docs site (GitHub Pages):

https://leonardovida.github.io/duckdb-sqlalchemy/

Examples

Development workflow

Install development dependencies:

pip install -e ".[dev,devtools]"

Run quick checks in your current environment:

pytest
nox -s ty
pre-commit run --all-files

Run the full compatibility matrix (slow):

nox -s tests

Release and support policy

  • Long-term maintenance: intended to remain supported.
  • Compatibility: track current DuckDB and SQLAlchemy releases while preserving SQLAlchemy semantics.
  • Breaking changes: only in major/minor releases with explicit notes in CHANGELOG.md.
  • Security: open an issue with details; fixes are prioritized.

Changelog and roadmap

Contributing

See AGENTS.md for repo-specific workflow, tooling, and PR expectations. We welcome issues, bug reports, and high-quality pull requests.

License

MIT. See LICENSE.txt.

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

duckdb_sqlalchemy-1.5.2.2.tar.gz (205.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

duckdb_sqlalchemy-1.5.2.2-py3-none-any.whl (62.4 kB view details)

Uploaded Python 3

File details

Details for the file duckdb_sqlalchemy-1.5.2.2.tar.gz.

File metadata

  • Download URL: duckdb_sqlalchemy-1.5.2.2.tar.gz
  • Upload date:
  • Size: 205.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for duckdb_sqlalchemy-1.5.2.2.tar.gz
Algorithm Hash digest
SHA256 a2699d1a5583659f013e48cd1b21c61fa60eec012023a95cdbef8e45d74abcea
MD5 1e59e6f48c9090a34018a59afc5b5aa7
BLAKE2b-256 ffb97c48ac65d49f7eb80511bb9a24e4093e736680418560432eec083da76d39

See more details on using hashes here.

Provenance

The following attestation bundles were made for duckdb_sqlalchemy-1.5.2.2.tar.gz:

Publisher: publish.yaml on leonardovida/duckdb-sqlalchemy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file duckdb_sqlalchemy-1.5.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for duckdb_sqlalchemy-1.5.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d13fa8262acf76ebf77becb468418535371a05afa80247009c3407fc6a50fb6a
MD5 c5db628c3bea239c08c7d607d2e4fd26
BLAKE2b-256 5732c16d3b124c2c256929f84d90e2e1471c15d4529cbea749b2b574a45496b0

See more details on using hashes here.

Provenance

The following attestation bundles were made for duckdb_sqlalchemy-1.5.2.2-py3-none-any.whl:

Publisher: publish.yaml on leonardovida/duckdb-sqlalchemy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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